python笔记图片_Python PIL学习笔记(一)

一、图片的读取和格式保存

1、读取静态图

import Image, os

im = Image.open('D:\\1.jpg')    #打开图片

im.save('new.jpg')    #图像对象的保存

print im.size, im.format, im.mode    #查看图片的各种属性

2、读取动态图

PIL默认载入图像的第一帧,可以利用seek和tell方法在各个帧之间移动。

im.seek(1)    # skip to the second frame

try:

while 1:

im.seek(im.tell() + 1)    #当前帧 + 1

except EOFError:

pass

二、图片的简单操作

1、切分

box = (100, 100, 200, 200)    #正方形对角点

region = im.crop(box)    #在im中找到box大小的图片,并赋给新的图片对象

2、反转、粘贴操作

region = region.transpose(Image.ROTATE_180)    #反转

im.paste(region, box)    #将region放到im的box位置

3、调整大小,旋转

out_size = img.resize((128, 128))#resize成128*128像素大小。

out_rotate = img.rotate(45)#逆时针旋转45度

4、RGB

每一个RGB都是由三个通道的灰度图叠加的,所以pil提供了将这三个通道分离的方法。

这里如果只用split()会出现问题,应该先获得数据

im.getdata()

r,g,b = im.split()    #分离三个通道

#这里可以看一下分别的情况

r.show()

g.show()

b.show()

#融合三个通道

out_merge = Image.merge("RGB", (r, g, b))    #这里可以互换r, g, b

5、转化灰度图像

out_L = im.convert('L')

6、融合图片

将两张图片大小相同的图片融合

Image.blend(im1, im2, alpha)    alpha参数大小决定im1----->im2,0时为im1,1时为im2。

im1 = Image.open('1.jpg')

im2 = Image.open('jpg')

#这里可以用上面的box切分图片或者用resize转换为相同大小

out = Image.blend(im1, im2, 0.5)

三、常用滤镜

1、加强滤镜

import ImageFilter

out_Detail = im.filter(ImageFilter.DETAIL)

或者直接用lambda表达式,增大像素点亮度

out_point = im.point(lambda i : i * 1.2)

还可以用ImageEnhance模块

import ImageEnhance

en = ImageEnhance.Contrast(im)

out = en.enhance(1.5)

2、边缘化滤镜

im = im.filter(ImageFilter.EDGE_ENHANCE)

3、转化灰度图像

im = im.convert("L")

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值