Pillow,PIL库,常用功能

官方查询网站:http://effbot.org/imagingbook/

中文手册:https://pillow-cn.readthedocs.io/zh_CN/latest/

英文手册:https://pillow.readthedocs.io/en/5.2.x/reference/Image.html

一、常用功能

转载自:URl-team

Python 里面最常用的图像操作库是Image library(PIL),功能上,虽然还不能跟Matlab比较,但是还是比较强大的,写点记录笔记。

 

getbbox() 包含非零区域的最小bbox
histogram(mask=None) 统计直方图
offset(dx,dy=None) 平移
putpixel(xy, color) 改变单个像素点颜色
thumbnail(size,filter=None) 缩略图
transform(xs, ys, Image.AFFINE, (a,b,c,d,e,f)) affine变换
transpose(method) 翻转旋转

 

1. 首先需要导入需要的图像库:

import Image

2. 读取一张图片:

im=Image.open(‘/home/Picture/test.jpg’)

3. 显示一张图片:

im.show()

4. 保存图片:

im.save(“save.gif”,”GIF”)      #保存图像为gif格式

5. 创建新图片:

Image.new(mode, size)

Image.new(mode, size, color)

栗子:newImg = Image.new(“RGBA”,(640,480),(0,255,0))
newImg.save(“newImg.png”,”PNG”)

6. 两张图片相加:

Image.blend(img1, img2, alpha)    # 这里alpha表示img1和img2的比例参数

7. 点操作:

im.point(function) #,这个function接受一个参数,且对图片中的每一个点执行这个函数
比如:out = im.point(lambda i : i*1.5)#对每个点进行50%的加强

8. 查看图像信息:
im.format, im.size, im.mode

9.  图片裁剪:
box = (100,100,500,500)  #设置要裁剪的区域

region = im.crop(box)     #此时,region是一个新的图像对象。

10. 图像黏贴(合并)

im.paste(region, box)#粘贴box大小的region到原先的图片对象中。

11. 通道分离:
r,g,b = im.split()#分割成三个通道  ,此时r,g,b分别为三个图像对象。

12. 通道合并:
im = Image.merge(“RGB”, (b, g, r))#将b,r两个通道进行翻转。

13. 改变图像的大小:
out = img.resize((128, 128))#resize成128*128像素大小

14. 旋转图像:
out = img.rotate(45) #逆时针旋转45度
有更方便的:
region = region.transpose(Image.ROTATE_180)

15. 图像转换:
out = im.transpose(Image.FLIP_LEFT_RIGHT)#左右对换。

  out= im.transpose(Image.FLIP_TOP_BOTTOM)#上下对换

16. 图像类型转换:
im=im.convert(“RGBA”)

17. 获取某个像素位置的值:
im.getpixel((4,4))

18.  写某个像素位置的值:
img.putpixel((4,4),(255,0,0))

二、Image 和array格式转换

img = Image.open()

img_array = np.array(img)  #Image转成array矩阵

img = Image.fromarray(np.uint8(img_array)) # array转成Image

你可能感兴趣的:(python)