PIL库的学习
Posted nicefurmine
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PIL库的学习相关的知识,希望对你有一定的参考价值。
PIL库概述
PIL库可以完成图像归档和图像处理两方面功能需求:
图像归档:对图像进行批处理、生成图像预览、图像格式转换等;
图像处理:图像基本处理、像素处理、颜色处理等。
基本方法:①Image.open(filename):根据参数加载图像文件。可填入图像的具体的储存位置。②<图像变量>.save(‘储存地址‘):储存处理后的图像。
1、Image类。【任何一个图像文件都可以用Image对象表示Image类的图像读取和创建方法】
from PIL import Image
这里只简要解析几个方法。
<1>Image.thumbnail(size):创建图像的缩略图,size是缩略图尺寸的二元元组。
实例:
1 pA = Image.open("D:桌面pytest景色1.jpg") #打开 2 pA.thumbnail((128,128)) #缩略 3 pA.save("D:桌面pytest景色1_TN.jpg") #保存
原图(1)
缩略图
<2>Image.point(func):根据函数func功能对每个元素进行运算,返回图像副本。
<3>Image.split():提取RGB图像的每个颜色通道,返回图像副本。
<4>Image.merge(mode,bands):合并通道 ,采用mode色彩,bands是新色的色彩通道。
实例:
1 pB = Image.open("D:桌面pytest景色2.jpeg") #打开 2 #改变颜色 3 r,g,b = pB.split() #获得RGB通道数据 4 newr = r.point(lambda i:i*1.5) # 将R通道颜色值变为原来的1.5倍 5 newb = b.point(lambda i:i*0.8) # 将b通道颜色值变为原来的0.8倍 6 newpB_merge = Image.merge(pB.mode, (newr, g, newb)) # 将3个通道合形成新图像 7 newpB_merge.save("D:桌面pytest景色2_Merge.jpeg")
原图 (2)
改变颜色后
2、ImageFilter类和ImageEnhance类。【PIL库的ImageFilter类和ImageEnhance类提供了过滤图像和增强图像的方法】ps:此处只列举ImageFilter的几个方法。
from PIL import ImageFilter
可利用Image类的filter()方法使用ImageFilter类,如:Image.filter(ImageFilter.fuction)
<1>ImageFilter.CONTOUR:图像的轮廓效果。
实例:(此处使用原图(2))
1 from PIL import Image 2 from PIL import ImageFilter 3 4 pB = Image.open("D:桌面pytest景色2.jpeg") #打开 5 6 #轮廓 7 newpB_contour = pB.filter(ImageFilter.CONTOUR) 8 newpB_contour.save("D:桌面pytest景色2_Contour.jpg")
轮廓图
<2>ImageFilter.EMBOSS:图像的浮雕效果。
实例:(此处使用原图(1))
1 from PIL import Image 2 from PIL import ImageFilter 3 pA = Image.open("D:桌面pytest景色1.jpeg") #打开 4 5 #浮雕 6 newpA_emboss = pA.filter(ImageFilter.EMBOSS) 7 newpA_emboss.save("D:桌面pytest景色1_Emboss.jpg")
浮雕图
————————————————————--------------------------------------------------——————————————————————-
图像字符化绘制
1 from PIL import Image 2 ascii_char = list(‘"$%_&WM#*oahkbdpqwmZO0QLCJUYXzcvunxr 3 jft/|()1{}[]?-/+@<>i!;:,^`.‘) 4 def get_char(r, b, g, alpha=256): 5 if alpha == 0: 6 return ‘ ‘ 7 gray = int(0.2126 * r + 0.7152 * g + 0.0722 * b) #灰色rbg 8 unit = 256 / len(ascii_char) 9 return ascii_char[int(gray//unit)] 10 def main(): 11 im = Image.open(‘D:桌面pytestpicture7.png‘) 12 WIDTH, HEIGHT = 500,300 13 im = im.resize((WIDTH, HEIGHT)) 14 txt = "" 15 for i in range(HEIGHT): 16 for j in range(WIDTH): 17 txt += get_char(*im.getpixel((j, i))) #getpixel函数是用来获取图像中某一点的像素的RGB颜色值,getpixel的参数是一个坐标点。对于图象的不同的模式,getpixel函数返回的值有所不同。 18 txt += ‘ ‘ 19 fo = open("D:桌面pytestpic_char.txt","w") 20 fo.write(txt) 21 fo.close() 22 main()
1 from PIL import Image 2 im = Image.open(‘D:桌面pytestekilled.gif‘) # 读入一个GIF文件 3 try: 4 im.save(‘D:桌面pytestpicframe{:02d}.png‘.format(im.tell())) 5 while True: 6 im.seek(im.tell()+1) #文件seek()的运用。改变当前文件操作指针的位置,offset的值:0:文件开头; 1: 当前位置; 2: 文件结尾 7 im.save(‘D:桌面pytestpicframe{:02d}.png‘.format(im.tell())) 8 except: 9 print("处理结束")
(gif文件来源百度)
自制生成GIF
小编将上面处理过的一些图像生成GIF,为此将图像统一存放在一个文件夹里(并重命名),且都转化为png格式。
1 from PIL import Image 2 imgs = [] 3 for i in range(1,12): 4 pic_name = ‘D:桌面素材picture{}.png‘.format(i) 5 picture = Image.open(pic_name) 6 temp = picture.resize((400,250)) 7 imgs.append(temp) 8 9 imgs[0].save(‘D:桌面素材合成.gif‘,save_all=True, append_images=imgs, duration=0.1)
【后记:若您在阅读过程中发现问题,请您斧正,小编将不胜感激。】
以上是关于PIL库的学习的主要内容,如果未能解决你的问题,请参考以下文章