python—PIL使用

引言

  PIL:Python Imaging Library,已经是Python平台事实上的图像处理标准库了。PIL功能非常强大,但API却非常简单易用。由于PIL仅支持到Python 2.7,加上年久失修,于是一群志愿者在PIL的基础上创建了兼容的版本,名字叫Pillow,支持最新Python 3.x,又加入了许多新特性,因此,我们可以直接安装使用Pillow。

一、安装Pillow

  如果安装了Anaconda,Pillow就已经可用了。否则,需要在命令行下通过pip安装。
我用的Anaconda+pycharm,安装会出现如下情况:

(base) C:\Users\admin>activate tf-gpu # 激活当前使用的虚拟环境

(tf-gpu) C:\Users\admin>pip install pillow # 安装
Requirement already satisfied: pillow in d:\softwares\anaconda3\envs\tf-gpu\lib\site-packages (8.0.1)

二、操作图像

  最常见的图像缩放操作,只需三四行代码。

from PIL import Image

# 打开一个jpg图像文件,注意是当前路径:
im = Image.open('test.jpg')
# 获得图像尺寸:
w, h = im.size
print('Original image size: %sx%s' % (w, h))
# 缩放到50%:
im.thumbnail((w//2, h//2))
print('Resize image to: %sx%s' % (w//2, h//2))
# 把缩放后的图像用jpeg格式保存:
im.save('thumbnail.jpg', 'jpeg')

其他功能如切片、旋转、滤镜、输出文字、调色板等一应俱全。
  模糊效果也只需几行代码:

from PIL import Image, ImageFilter

# 打开一个jpg图像文件,注意是当前路径:
im = Image.open('test.jpg')
# 应用模糊滤镜:
im2 = im.filter(ImageFilter.BLUR)
im2.save('blur.jpg', 'jpeg')

在这里插入图片描述
  PIL的ImageDraw提供了一系列绘图方法,让我们可以直接绘图。比如要生成字母验证码图片:

from PIL import Image, ImageDraw, ImageFont, ImageFilter

import random

# 随机字母:
def rndChar():
    return chr(random.randint(65, 90))

# 随机颜色1:
def rndColor():
    return (random.randint(64, 255), random.randint(64, 255), random.randint(64, 255))

# 随机颜色2:
def rndColor2():
    return (random.randint(32, 127), random.randint(32, 127), random.randint(32, 127))

# 240 x 60:
width = 60 * 4
height = 60
image = Image.new('RGB', (width, height), (255, 255, 255))
# 创建Font对象:(字体)
font = ImageFont.truetype('arial.ttf', 36)
# 创建Draw对象:
draw = ImageDraw.Draw(image)
# 填充每个像素:
for x in range(width):
    for y in range(height):
        draw.point((x, y), fill=rndColor())
# 输出文字:
for t in range(4):
    draw.text((60 * t + 10, 10), rndChar(), font=font, fill=rndColor2())
# 模糊:
image = image.filter(ImageFilter.BLUR)
image.save('code.jpg', 'jpeg')

用随机颜色填充背景,再画上文字,最后对图像进行模糊,得到验证码图片如下:
在这里插入图片描述
  定义一个保存图像(多张Image保存到一张Image)的函数:

# 定义Image保存函数,将多张Image保存到一张Image里面去
def save_images(imgs,name):
    news_im = Image.new('L',(280,280))

    index = 0
    # 将10张Image保存到一张Image里面去
    for i in range(0,280,28):
        for j in range(0,280,28):
            im = imgs[index]
            im = Image.fromarray(im,mode='L')
            news_im.paste(im,(i,j))
            index += 1

        news_im.save(name)

三、上述操作总结

Image.open(path)
打开path路径的图像文件
im = Image.open(path)

w, h = im.size
获取图像实例的尺寸

im.thumbnail((w_new, h_new))
将原图像实例缩放到新的尺寸(w_new, h_new)

im.save(‘thumbnail.jpg’, ‘jpeg’)
保存图片,图片名为thumbnail.jpg,格式为’jpeg’

im.filter(ImageFilter.BLUR)
应用模糊滤镜

Image.new(mode, size, color=0)
mode:https://pillow.readthedocs.io/en/stable/handbook/concepts.html#concept-modes
使用给定的模式和大小创建一个新图像

Image.fromarray(obj, mode=None)
使用给定的模式将array对象转换为image对象
obj – Object with array interface
mode – Mode to use (will be determined from type if None)

ImageFont.truetype(font=None, size=10, index=0, encoding=’’, layout_engine=None)
这个函数从给定的文件或类文件对象中加载一个字体对象,并为给定大小的字体创建一个字体对象
font:字体对象
size:字体尺寸
index:要加载的字体

参考:

  1. 廖雪峰教程
  2. Pillow官网

猜你喜欢

转载自blog.csdn.net/weixin_46649052/article/details/114256239