共计 2642 个字符,预计需要花费 7 分钟才能阅读完成。
Python 骚操作 | 用 Python 来 P 图
给大家带来一篇关于 PIL 的文章,PIL 全称是 Python Image Library,顾名思义,是用来做图像处理的。用这个库,可以实现很多 PS 里的效果,比如像图片模糊、寻找轮廓、边缘检测等等。我们来看看具体怎么做到的呢?
PS 作为世界四大发明之一可以说被广大网友用到了极致,只有你想不到的没有我 P 不了的,任何正经的图片在都可以变成搞笑图片(比如下图)当然也可以用 ps 做一点正经的事情。
作为一个爱折腾的程序猿能用代码的解决的事情绝对不会用其他的方式,Python 可以打飞机,人工降雪,那么 p 个图对于 Python 来说是小儿科了,今天就教给大家 Python 之 p 图大法。
具体介绍
今天 P 图主要用到的就是 PIL 库。PIL(Python Image Library)是 python 的第三方图像处理库,但是由于其强大的功能与众多的使用人数,几乎已经被认为是 python 官方图像处理库了,今天只是简单的学习了几个方法就已经感受到 PIL 的强大。PIL 可以做很多和图像处理相关的事情: 图像归档 (Image Archives)。PIL 非常适合于图像归档以及图像的批处理任务。你可以使用 PIL 创建缩略图,转换图像格式,打印图像等等。图像展示(Image Display)。PIL 较新的版本支持包括 TkPhotoImage,BitmapImage 还有 Windows DIB 等接口。PIL 支持众多的 GUI 框架接口,可以用于图像展示。图像处理(Image Processing)。PIL 包括了基础的图像处理函数,包括对点的处理,使用众多的卷积核(convolution kernels) 做过滤(filter), 还有颜色空间的转换。PIL 库同样支持图像的大小转换,图像旋转,以及任意的仿射变换。PIL 还有一些直方图的方法,允许你展示图像的一些统计特性。这个可以用来实现图像的自动对比度增强,还有全局的统计分析等。
今天先给大家介绍今天学到的三个比较好玩的操作,并没有详细的介绍 PIL 那些最常用的特性与用法,感兴趣的小伙伴文末留言如果人数较多会考虑分享常用的特性。主要参考自:http://www.effbot.org/imaging…
代码实现
先上一个效果图。实现这个效果使用的是 PIL 中的 Blend 类
Image.blend(image1,image2,alpha)
⇒image
使用给定的两张图像及透明度变量 alpha,插值出一张新的图像。这两张图像必须有一样的尺寸和模式。
合成公式为:out=image1(1.0- alpha)+image2alpha
若变量 alpha 为 0.0,返回第一张图像的拷贝。若变量 alpha 为 1.0,将返回第二张图像的拷贝。对变量 alpha 的值无限制。
from PIL import Image
im1 = Image.open(“124.jpg”)
im2 = Image.open(“123.jpg”)
print(im1.mode,im1.size)
print(im2.mode,im2.size)
im = Image.blend(im1, im2, 0.3)
im.save(‘k3.jpg’)
当然除了上面的方法还可以使用 Composite 类 Image.composite(image1,image2, mask) ⇒ image 复合类使用给定的两张图像及 mask 图像作为透明度,插值出一张新的图像。变量 mask 图像的模式可以为“1”,“L”或者“RGBA”。所有图像必须有相同的尺寸。
from PIL import Image
im1 = Image.open(“124.jpg”)
im2 = Image.open(“123.jpg”)
r,g,b = im1.split()
print(b.mode)
print(im1.mode,im1.size)
print(im2.mode,im2.size)
im = Image.composite(im1,im2,b)
im.save(‘k1.jpg’)
自己只是做了一个简单的测试大家可以通过这种方法做出更好看的图片,PIL 不仅可以使两张图片进行重合,还可以给图片添加水印。
from PIL import Image, ImageDraw,ImageFont
#将原来的图片转换为 RGBA 模式
im = Image.open(r”timg2.png”).convert(‘RGBA’)
#新建一个图片,尺寸与上面的尺寸一样,透明度为 0 即完全透明
txt=Image.new(‘RGBA’, im.size, (0,0,0,0))
#设置要写文字的字体
fnt=ImageFont.truetype(“D:\PycharmProjects\music\SIMYOU.TTF”, 30)
#打汉字
d=ImageDraw.Draw(txt)
#写要打的位置,内容, 用的字体,文字透明度
d.text((txt.size[0]-205,txt.size[1]-50),”@Ahab 杂货铺 ”,font=fnt, fill=(255,0,0,300))
#两个图片复合
out=Image.alpha_composite(im, txt)
#保存加水印后的图片
out.save(r”KB.png”)
下面带来最后一组有趣的操作:
Filter 类
im.filter(filter) ⇒ image
返回一个使用给定滤波器处理过的图像的拷贝。在该模块中,预先定义了很多增强滤波器,可以通过 filter()函数使用,预定义滤波器包括:
BLUR
CONTOUR
DETAIL
EDGE_ENHANCE
EDGE_ENHANCE_MORE
EMBOSS
FIND_EDGES
SMOOTH
其中 BLUR 就是均值滤波,CONTOUR 找轮廓,FIND_EDGES 边缘检测,使用该模块时,需先导入。
from PIL import Image
from PIL import ImageFilter ## 调取 ImageFilter
img = Image.open(“123.jpg”)
blu = imgF.filter(ImageFilter.BLUR) ## 均值滤波
con = imgF.filter(ImageFilter.CONTOUR) ## 找轮廓
edge = imgF.filter(ImageFilter.FIND_EDGES) ## 边缘检测
blu.save(‘k.jpg’)
con.save(‘k2.jpg’)
edge.save(‘k3.jpg’)
看一下效果第一张是原图,剩下的是根据我们设置的呈现的效果图。