【Python】分享几个用Python给图片添加水印的方法,简单实用

今天来分享几种可以给图片添加水印的方法,都是十分的简单实用,大家在看了之后也可以私底下去自己试试,有些方法需要的代码量就比较少,有些方法需要的代码量就稍微多一些,那我们开始吧

6563d77185695517527168ec45af4f38.png

opencv模块

94f02e6bd25132a6297eca837b99151a.png

首先我们用opencv这个库来给图片添加水印,主要用到的函数是cv2.putText()方法,里面共有大概9个参数,当然我们并不需要将这个9个参数统统用到,

下面分别为大家来讲述一下cv2.putText()方法中9个参数的含义,介绍如下:

  • image:印有水印的图片

  • text:水印的具体文字

  • org:水印放置的横纵坐标,(x坐标,y坐标)

  • font、fontScale:水印的字体相关的参数

  • color:水印的颜色

  • thinkness、lineType、bottomLeftOrigin:印有水印的图片相关的设置,线条的粗细哇、线条的样式哇等等

下面我们来看一下具体的代码把

img=cv2.imread("test2.jpg") # 导入我们需要添加水印的图片
RGB_img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
blank_img = np.zeros(shape=(RGB_img.shape[0],RGB_img.shape[1],3), dtype=np.uint8)
font = cv2.FONT_HERSHEY_SIMPLEX
# 添加水印的文字内容
cv2.putText(blank_img,text='Learn Python',org=(40, 90),
            fontFace=font,fontScale= 2,
            color=(255,0,0),thickness=10,lineType=cv2.LINE_4)

然后我们将印有水印的图片和原图进行结合,代码如下

blended = cv2.addWeighted(src1=RGB_img, alpha=0.7,
                          src2=blank_img, beta=1, gamma = 2)
plt.imshow(blended)

出来的结果是这样

c39bc381692af2f917051c781ebbd312.png

95398a19cf4d8bff662947de6dd7bc0c.png

PIL模块

a7e73032af6237b133a1fe0d8b68fe43.png

PIL是Python的第三方图像处理库,其中Image模块作为PIL库的基本核心类,可以用来例如加载图像和创建新图像等用途,而说到给在图片上添加水印,要用到的方法就是ImageDraw.Draw.text(),里面有包括6个参数,其中经常被用到的也就下面四个

  • xy:添加水印的坐标,x坐标和y坐标

  • text:具体添加水印的文本内容

  • fill、font:具体文本内容的样式、字体大小等等

下面我们来看一下具体的代码长什么样子

im = Image.open('test1.jpg')
draw = ImageDraw.Draw(im)
text = "Learn Python"
# 设置字体、字体大小等等
font = ImageFont.truetype('arial.ttf', 33)
# 添加水印
draw.text((50, 50), text, font=font)
im.show()
# 保存图片
im.save('watermark2.jpg')

出来的结果是这个样子

153f4e1cee0d0bd5ae5570bc568e35e8.png

24912b9e41935824dfe232f52f3322ef.png

filestools模块

e93a6462081f2652e133d1ef2b41c858.png

最后我们要介绍的则是filestools模块,其本质上也是对ImageDraw.Draw.text()方法做了进一步的封装,让我们用起来会更加的简便,对比前者,我们使用add_mark()方法可以生成数量较多的水印,该方法当中里面有8个参数,其中比较重要的几个是

  • mark:水印的文字内容

  • color、size、opacity、space、angle:水印文字的样式包括文字的大小、颜色、透明程度等等

我们现在来看一下具体的代码

from watermarker.marker import add_mark
add_mark(file = "test1.jpg", out = "add_mark_test1.jpg",
         mark = "Python", opacity=0.2, angle=30, space=30)

出来的结果长这个样子

3f0d843fb7d189a3e94fdca4cee4285c.png

具体采用哪种方法,读者可以自己斟酌地来使用,学习愉快!

 
 

bc3738f8c3c2f4de5c1aa32a798b55c2.png

 
 
 
 
 
 
往期精彩回顾




适合初学者入门人工智能的路线及资料下载机器学习及深度学习笔记等资料打印机器学习在线手册深度学习笔记专辑《统计学习方法》的代码复现专辑
AI基础下载机器学习的数学基础专辑黄海广老师《机器学习课程》视频课

本站qq群851320808,加入微信群请扫码:

11dd36626f3345cf7d0e536e166a142a.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值