时间:2021-05-23
PIL基本功能介绍
from PIL import Imagefrom PIL import ImageEnhance img = Image.open(r'E:\img\f1.png')img.show()#图像二值化img = img.convert('L')# 图像放大img = img.resize((img.width * int(3), img.height * int(4)), Image.ANTIALIAS)# # 对比度增强enh_con = ImageEnhance.Contrast(img)contrast = 2img_contrasted = enh_con.enhance(contrast)# 亮度增强enh_bri = ImageEnhance.Brightness(img_contrasted)brightness = 2.5image_brightened = enh_bri.enhance(brightness)#色度增强enh_col = ImageEnhance.Color(img)color = 50image_colored = enh_col.enhance(color)# # 锐度增强enh_sha = ImageEnhance.Sharpness(img)sharpness = 2image_sharped = enh_sha.enhance(sharpness)image_sharped.save(r'E:\img\f22.png', dpi=(300, 300), quality=95)# image_sharped.save(r'E:\img\f22.png') # 图片汉字识别img2 = Image.open(r'E:\img\f22.png')code2 = pytesseract.image_to_string(img2, lang='chi_sim')# print(code2)# 图片裁剪image_cro = Image.open(r'E:\img\f24.png')image_cropped = image_cro.crop(res)image_cropped.save(u'E:\img\\f25.png')对图片进行黑白化处理
img_main = Image.open(u'E:/login1.png')img_main = img_main.convert('L')threshold1 = 138table1 = []for i in range(256): if i < threshold1: table1.append(0) else: table1.append(1)img_main = img_main.point(table1, "1")img_main.save(u'E:/login3.png')计算小图在大图的坐标
def get_screenxy_from_bmp(main_bmp, son_bmp): # 获取屏幕上匹配指定截图的坐标->(x,y,width,height) img_main = Image.open(main_bmp) img_main = img_main.convert('L') threshold1 = 138 table1 = [] for i in range(256): if i < threshold1: table1.append(0) else: table1.append(1) img_main = img_main.point(table1, "1") img_son = Image.open(son_bmp) img_son = img_son.convert('L') threshold2 = 138 table2 = [] for i in range(256): if i < threshold2: table2.append(0) else: table2.append(1) img_son = img_son.point(table2, "1") datas_a = list(img_main.getdata()) datas_b = list(img_son.getdata()) for i, item in enumerate(datas_a): if datas_b[0] == item and datas_a[i + 1] == datas_b[1]: yx = divmod(i, img_main.size[0]) main_start_pos = yx[1] + yx[0] * img_main.size[0] match_test = True for n in range(img_son.size[1]): main_pos = main_start_pos + n * img_main.size[0] son_pos = n * img_son.size[0] if datas_b[son_pos:son_pos + img_son.size[0]] != datas_a[main_pos:main_pos + img_son.size[0]]: match_test = False break if match_test: return (yx[1], yx[0], img_son.size[0], img_son.size[1]) return FalseImageGrab实现屏幕截图
im = ImageGrab.grab()im.save('D:/as1.png') # # # # 参数说明# # # # 第一个参数 开始截图的x坐标# # # # 第二个参数 开始截图的y坐标# # # # 第三个参数 结束截图的x坐标# # # # 第四个参数 结束截图的y坐标bbox = (897, 131, 930, 148)im = ImageGrab.grab(bbox)im.save('D:/as2.png')以上就是python PIL模块的基本使用的详细内容,更多关于python PIL模块的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Python生成随机验证码,需要使用PIL模块,具体内容如下安装:pip3installpillow基本使用1.创建图片fromPILimportImageim
本文实例讲述了python通过pil模块将raw图片转换成png图片的方法。分享给大家供大家参考。具体分析如下:python通过pil模块将raw图片转换成pn
本文实例讲述了python通过pil模块获得图片exif信息的方法。分享给大家供大家参考。具体分析如下:python的pil模块功能超级强大,不但可以用来处理图
本文实例讲述了python实现通过pil模块对图片格式进行转换的方法。分享给大家供大家参考。具体分析如下:python的pil模块相当的智能,如果你需要对图片格
Python获取电脑截图有多种方式,具体如下:PIL中的ImageGrab模块windowsAPIPyQtpyautoguiPIL中的ImageGrab模块im