Python中,主要使用的图像处理库是PIL(Python Imaging Library)、opencv、scikit-image
1. 用PIL读写图片1
from PIL import Image
path = 'data/timg.jpg'
img = Image.open(path)#读取图片
print(type(img))#<class 'PIL.PngImagePlugin.PngImageFile'>
print(img.mode,img.size,img.format)#RGB (2048, 1365) JPEG
img1 = np.array(img) ## 转成numpy形式
print(img1.shape)#(803, 599, 3)
## 在图片中放置文字
## 显示中文字符
## simsun.ttc 是宋体,可以显示中文.
## 字体在ubuntu下没有时,可以将字体文件复制到Ubuntu系统中去
font = ImageFont.truetype("simsun.ttc", 36) # 指定字体和字号
# 定义需要绘制的文本
text = "你好,世界!"
draw.text((40,40), text, font=font, fill=(0, 0, 255))
img.save('a.jpg')#保存图片
img.show()#显示图像
- PIL读出的图片是
PIL.PngImagePlugin.PngImageFile
格式。img.size
得到的尺寸是(W,H)
形式的,转换成numpy数据后就是(H,W,C)
.颜色模式img.mode
为RGB
。 - 如果在ubuntu系统运行,可能没有“simsun.ttc”字体,需要从windows系统复制过去,或者在网上下载。
1.1 PIL图片上画矩形
- 使用
draw.rectangle()
. - 使用说明参考官网
- 画圆角矩形
draw.rounded_rectangle
from PIL import ImageFont,ImageDraw,Image
img_path = 'woman_dog.jpg'
raw_image = Image.open(img_path).convert('RGB')
#下面就是设置字体的样式以及字体的大小,都是自行设置的
myFont = ImageFont.truetype('DENGL.TTF', 66)
#给图形中添加文本信息
draw = ImageDraw.Draw(raw_image)
text = 'Be happy!'
# 获取字符串的宽、高
text_width, text_height = draw.textsize(text, font=myFont)
# 画实心框,使用fill参数。第一个参数是框的(xmin,ymin,xmax,ymax)
draw.rectangle((40,120,40+text_width,120+text_height),fill=(0,255,255))
draw.text((40,106),text,font = myFont,fill=(255, 0, 255),direction=None)
x = 40
y = 150+text_height
## 画外框,使用outline参数
draw.rectangle((x,y,x+text_width,y+text_height),outline=(0,0,255),width = 3)
# #显示图片
raw_image.show()
画完实心框后,写字上去,给字添加背景色
2. opencv读写图片2
import cv2 as cv
img = cv.imread('data/timg.jpg') # 灰度模式读取图片
print(type(img))#<class 'numpy.ndarray'>
print(img.shape)#(803, 599, 3)
cv.imshow('image', img) # 显示图片,窗口名称为'image'
k = cv.waitKey(0) # 无限等待一个键击,将此键击存在k变量中
if k == 27: # 27代表esc,可以查看ascii码表
cv.destroyAllWindows() # 退出窗口
elif k == ord('s'): # 等待s键,ord函数可以将字符串转换为ascii码
cv.imwrite('a.png', img) # 写入图片
cv.destroyAllWindows() # 关闭窗口
opencv读出的图片是numpy.ndarray
格式。尺寸是
(H,W,C)形式.颜色模式为
BGR`。
3. scikit-image读写图片
from skimage.io import imshow,imsave
from matplotlib import pyplot as plt
img = io.imread('data/timg.jpg')#读取图片
print(type(img))#<class 'numpy.ndarray'>
print(img.shape)#(803, 599, 3)
imshow(img)#显示图像要借助matplotlib库
imsave('a3.jpg',img)#保存图像
plt.show()#显示图像
scikit-image读出的图片是numpy.ndarray
格式。尺寸是
(H,W,C)形式.颜色模式为
RGB`。
python中PIL.Image和OpenCV图像格式相互转换
PIL转opencv
import cv2
from PIL import Image
import numpy
image = Image.open("plane.jpg")
image.show()
img = cv2.cvtColor(numpy.asarray(image),cv2.COLOR_RGB2BGR)
cv2.imshow("OpenCV",img)
cv2.waitKey()
###opencv转PIL
import cv2
from PIL import Image
import numpy
img = cv2.imread("plane.jpg")
cv2.imshow("OpenCV",img)
image = Image.fromarray(cv2.cvtColor(img,cv2.COLOR_BGR2RGB))
image.show()
cv2.waitKey()