python图像识别介绍_Python图像识别-打码访问

Python的强大,在于它有非常多的第三方库。对于验证码识别,Python也已经有了现成的库来供我们使用了。开源的OCR库pytesseract配合tesseract,可以用来将图片中的文字转化为文本。

不过这种方式我们在爬虫中用的并不多。因为现在大部分的验证码都加上了干扰的纹理,已经很少能用单机版的图片识别方式来识别了。所以我们这里仅仅使用简单地图片来进行介绍。如果有一天你的运气足够好,遇到了非常工整的验证码,那么你可以使用这个办法来试一试。

安装 tesseract

(1) Windows

请在这里下载安装包:https://github.com/tesseract-ocr/tesseract/wiki/Downloads

在3rd party Windows exe’s/installer下面可以找到exe安装包。

(2) Mac

使用homebrew安装:

brew install tesseract

(3) Linux

使用apt-get安装:

sudo apt-get install tesseract-orc

更多的安装帮助信息,可以参阅:https://github.com/tesseract-ocr/tesseract/wiki

安装 Python库

要使用tesseract来做图像识别,我们还需要安装两个库:

pip install Pillow

pip install pytesseract

tesseract的使用

tesseract的使用非常简单,流程如下:

导入相关的第三方库

打开图片

识别

我们可以通过以下代码来实现最简单的图片识别:

import pytesseract

from PIL import Image

image = Image.open('验证码.png')

code = pytesseract.image_to_string(image)

print(code)

运行结果如下:

tesseract.png

如果你的系统为Mac OS,并且使用homebrew安装tesseract,那么你一定会遇到下面的报错信息:

error.png

你需要修改Python安装文件夹下面的lib/site-packages/pytesseract文件夹下面的 pytesseract.py 文件,将第60行的:

tesseract_cmd = 'tesseract'

修改为:

tesseract_cmd = '/usr/local/bin/tesseract'

好的,你的问题是:Python如何使用OpenCV识别图像中的人像并打马赛克? 人像识别是计算机视觉领域的一个重要应用场景,而OpenCV是一个强大的计算机视觉库,能够提供丰富的图像处理功能。下面是使用Python和OpenCV进行人像识别并打马赛克的步骤: 1. 导入所需的Python库: ```python import cv2 import numpy as np ``` 2. 加载待处理的图片: ```python img = cv2.imread('test.jpg') ``` 3. 创建一个人脸检测器: ```python face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml') ``` 4. 使用人脸检测器进行人脸检测: ```python gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) faces = face_cascade.detectMultiScale(gray, 1.3, 5) ``` 5. 对于每个检测到的人脸,使用矩形框标出: ```python for (x,y,w,h) in faces: cv2.rectangle(img,(x,y),(x+w,y+h),(0,0,255),2) ``` 6. 对每个人脸进行马赛克处理: ```python for (x,y,w,h) in faces: roi = img[y:y+h, x:x+w] roi = cv2.resize(roi, (w//10, h//10)) roi = cv2.resize(roi, (w, h), interpolation=cv2.INTER_LINEAR) img[y:y+h, x:x+w] = roi ``` 7. 显示处理后的图片: ```python cv2.imshow('image',img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 完整代码如下: ```python import cv2 import numpy as np img = cv2.imread('test.jpg') face_cascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml') gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) faces = face_cascade.detectMultiScale(gray, 1.3, 5) for (x,y,w,h) in faces: cv2.rectangle(img,(x,y),(x+w,y+h),(0,0,255),2) roi = img[y:y+h, x:x+w] roi = cv2.resize(roi, (w//10, h//10)) roi = cv2.resize(roi, (w, h), interpolation=cv2.INTER_LINEAR) img[y:y+h, x:x+w] = roi cv2.imshow('image',img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 希望能对你有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值