Python批量图片去水印,提高工作效率
平常工作中,有时为了采用网络的一些素材,但这些素材往往被打了水印,如果我们不懂PS就无法去掉水印,或者无法批量去掉水印。这些就很影响我们的工作效率。
今天我们就一起来,用Python + OpenCV三步去除水印,去水印需要使用的库:cv2、numpy。cv2是基于OpenCV的图像处理库,可以对图像进行腐蚀,膨胀等操作;numpy这是一个强大的处理矩阵和维度运算的库。
图片去水印原理
1、标定噪声的特征,使用cv2.inRange二值化标识噪声对图片进行二值化处理,具体代码:cv2.inRange(img, np.array([200, 200, 240]), np.array([255, 255, 255])),把[200, 200, 200]~[255, 255, 255]以外的颜色处理为0;
2、使用OpenCV的dilate方法,扩展特征的区域,优化图片处理效果;
3、使用inpaint方法,把噪声的mask作为参数,推理并修复图片。
去掉右下角的水印步骤
1、从源图片,截取右下角部分,另存为新图片;
2、识别水印,颜色值为:[200, 200, 200]~[255, 255, 255]
3、去掉水印,还原图片;
4、把源图片、去掉水印的新图片,进行重叠合并;
实现代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | import cv2 import numpy as np from PIL import Image import os dir = os.getcwd() path = "1.jpg" newPath = "new.jpg" img = cv2.imread(path, 1 ) hight,width,depth = img.shape[ 0 : 3 ] #截取 cropped = img[ int (hight * 0.8 ):hight, int (width * 0.7 ):width] # 裁剪坐标为[y0:y1, x0:x1] cv2.imwrite(newPath, cropped) imgSY = cv2.imread(newPath, 1 ) #图片二值化处理,把[200,200,200]-[250,250,250]以外的颜色变成0 thresh = cv2.inRange(imgSY,np.array([ 200 , 200 , 200 ]),np.array([ 250 , 250 , 250 ])) #创建形状和尺寸的结构元素 kernel = np.ones(( 3 , 3 ),np.uint8) #扩展待修复区域 hi_mask = cv2.dilate(thresh,kernel,iterations = 10 ) specular = cv2.inpaint(imgSY,hi_mask, 5 ,flags = cv2.INPAINT_TELEA) cv2.imwrite(newPath, specular) #覆盖图片 imgSY = Image. open (newPath) img = Image. open (path) img.paste(imgSY, ( int (width * 0.7 ), int (hight * 0.8 ),width,hight)) img.save(newPath) |
效果对比
实现效果如下图,这个默认是去掉白色右下角的水印,大家可以根据自己的需求进行更改。
好了,今天就分享到这边,大家有什么想法,欢迎给我留言讨论。如果需要源代码与软件的,请在公众号回复【去水印】获取。
文章首发公众号【编程乐趣】,欢迎关注。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了