Python实现图片批量加入水印代码实例
作者:白玉无冰 发布时间:2022-07-13 10:47:04
这篇文章主要介绍了Python实现图片批量加入水印代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
写文章的时候可以设置是否添加水印。可是,有些图片可能想加水印,有些不想加水印,该怎么办呢?
配置环境
python3 + pillow
pip3 install pillow
引入库
from PIL import Image, ImageSequence
import os
import random
效果预览:
使用方法:
在脚本同目录下添加水印图片 logo.png
创建目录 input 并在放入要添加水印的图片
创建目录 output 执行脚本 addlogo.py
结果输出在 output 文件夹下
实现原理
水印图片采集:
先读取水印图片的像素点信息和大小信息。去除透明度为0的像素,并修改透明度像素信息。
img_logo = Image.open("logo.png")
img_logo_width, img_logo_height = img_logo.size
img_logo_pixels = dict()
for w in range(img_logo_width):
for h in range(img_logo_height):
c = img_logo.getpixel((w,h))
if c!=(0, 0, 0, 0):
img_logo_pixels[(w, h)] = c[:3]+(125,)
混合颜色:
对每一个像素点采取颜色混合,其中c1是源图片的像素点信息(r,g,b,a),c2是logo图片像素点的信息。混合算法如下:
def blendPixel(c1,c2):
a1=256-c2[3]
a2=c2[3]-(a1*c2[3])/256.0
a=a1+a2
c=(int((a1*c1[0] + a2*c2[0])/a), int((a1*c1[1] + a2*c2[1])/a), int((a1*c1[2] + a2*c2[2])/a),int(a))
return c
处理源 Image 对象:
随机一个位置开始处理像素,具体代码参考如下。
def dealOneImage(image,offX=None,offY=None):
w, h = image.size
offX = offX if offX else random.random();
offY = offY if offY else random.random();
#如果图片尺寸小于水印图片,不加水印
if w>=img_logo_width and h>=img_logo_height:
top = int((w - img_logo_width)*offX)
left = int((h - img_logo_height)*offY)
for p, c in img_logo_pixels.items():
p_x = (p[0]+top)
p_y = (p[1]+left)
image_c = image.getpixel((p_x,p_y))
if(isinstance(image_c, tuple) and len(image_c)>2):
image.putpixel((p_x, p_y), blendPixel(image_c,c))
return image;
处理单个文件:
对于 gif 文件先拆成一张一张图片,在图片上添加水印,最后再合成 gif 。对于其他格式的图片文件可以多添加几个水印。最后输出保存到 output 文件夹下。
def dealOneFile(filePath):
img_orign = Image.open(filePath)
_,file_type = os.path.splitext(filePath)
basename = os.path.basename(filePath)
if file_type == '.gif':
sequence = [];
offX=random.random()
offY=random.random()
for f in ImageSequence.Iterator(img_orign):
if len(sequence) % 2 == 0:
offX=random.random()
offY=random.random()
sequence.append(dealOneImage(f.convert(),offX,offY))
sequence[0].save(f'./output/{basename}', save_all=True, append_images=sequence[1:])
else:
image_out = (dealOneImage(img_orign))
for x in range(1):
image_out = (dealOneImage(image_out))
image_out.save(f'./output/{basename}')
处理目录:
对当前目录下的文件做一个筛选,只选取图片格式的文件。
def dealSrc(srcDir):
picFiles = [os.path.join(srcDir,fn) for fn in os.listdir(srcDir) if fn.endswith(('.gif', '.jpg', '.png','.jpeg'))]
for filePath in picFiles:
dealOneFile(filePath)
小结
添加水印主要用了 python3 中的 pillow 库来实现。 首先是读取 logo 图片信息,接着在随机一个位置添加混合后的像素点信息,最后再保存起来。
其中,对于 gif 文件的处理是拆帧,再添加水印,最后再组合成一个 gif。这个只能对应比较小的 gif 文件处理,如果有更好的方法欢迎留言交流分享!
来源:https://www.cnblogs.com/lamyoung/p/11958029.html


猜你喜欢
- 修改models效果如下class EmailVerifyRecord(models.Model): code = models
- python里的super().init()有什么用?对于python里的super().__init__()有什么作用,很多同学没有弄清楚
- 在使用数据库的时候,难免要在使用过程中进行删除的操作,如果是使用int类型的字段,令其自增长,这是个最简单的办法,但是后果会有些不是你想要的
- 所谓严格模式其实就是一个不会赋值给任何变量的字符串 “use strict”如果在全局作用域下 给出这个提示,那整个脚本将采用严格模式。也可
- ES6添加了Promise对象,成功时在then中处理,失败则在catch中处理,但有时候,我们需要在无论成功或失败时都要做一些事,比如隐藏
- 电脑安装git客户端、注册github账号并登陆到本地项目文件夹右键选择git bash here输入个人信息(代码提交者)git conf
- 1、下载MySQL官方的mysql-connector-python-8.0.17-py3.7-windows-x86-64bit.msi,
- 使用到的函数是curl_init, curl_setopt, curl_exec,curl_close。默认是GET方法,可以选择是否使用H
- 字典是可变的,并且可以存储任意数量的Python对象,包括其他容器类型另一个容器类型。字典包括键对(称为项目)及其相应的值。Py
- pymysql写入中文直接写入中文会出现错误。根据网上的方法,设置my.ini不成功sql = "INSERT INTO comp
- 大家通过手机自带浏览器打开百度、淘宝,在首页加载完毕后,会自动隐藏页面上方的地址栏,加之这些网站针对手机浏览器做了优化,乍看之下,还真难区分
- 本文实例为大家分享了Go实现文件上传和下载的具体代码,供大家参考,具体内容如下一.文件上传文件上传:客户端把上传文件转换为二进制流后发送给服
- 反射的优点它的核心本质其实就是基于字符串的事件驱动,通过字符串的形式去操作对象的属性或者方法一个概念被提出来,就是要明白它的优点有哪些,这样
- Golang 支持交叉编译,在一个平台上生成另一个平台的可执行程序,最近使用了一下,非常好用,这里备忘一下。Mac 下编译 Linux 和
- 记得导入包,其他按键可类比def keyPressEvent(self, event): if event.key() == Q
- 是不是有这么一个场景,对外提供一堆数据或者是要返回给用户一个结果。但是不想把内部的一些数据和逻辑暴露给对方。。。简单点来说,就是想以服务的方
- 前言这是我在搭建Django项目时候的过程,拿来总结记录,以备不时之需。项目采用nginx+uwsgi的搭配方式。项目依赖包采用 requi
- Upload组件是自带上传进度,但是样式调起来很麻烦,我们要做的就是自定义一个首先页面要引入组件 Upload, Progressuploa
- login <?php require "../include/DBClass.php"; $usern
- 需求需要生成一个宣传的图片分享到朋友圈,这个宣传图片包含二维码,包含不同的背景图片和不同的文字。对于这种图片生成,我们考虑过使用服务端生成,