网站首页 > 博客文章 正文
人脸识别是现在几乎所有的APP都在使用的验证操作, 登陆,支付...等等, 我们今天呢先来说一下人脸检测的操作. 使用Python想要完成人脸检测的操作呢, 我们需要准备一个工具, 这个工具就是 opencv
1. opencv的安装
open 开源 computer 计算机 vision 视觉 :开源计算机视觉库, 是由C++
Python胶水语言,粘结其他语言,调用opencv
这个库可以让计算机长眼睛,计算,可以‘看’!
安装操作
pip install opencv-python -i https://pypi.tuna.tsinghua.edu.cn/simple [opencv库]
pip install opencv-contrib-python -i https://pypi.tuna.tsinghua.edu.cn/simple [opencv扩展]
pip install numpy -i https://pypi.tuna.tsinghua.edu.cn/simple [numeric python 数字化Python]
安装完毕之后 我们先来简单的使用一下:
2.加载图片
import cv2 # 不是引入opencv opencv-python对Python封装的接口 都是存在cv2里的
# 读取图片
img = cv2.imread('./timg.jpg') # 图片的名称不能用汉字
print(img)
'''
三维的数据
最里层是像素:[颜色值] 每个像素的颜色值
颜色是由蓝绿红三色调色而成
[ 83 75 82]
蓝色 绿色 红色
每个颜色取值是0-255 值越大 颜色越鲜艳 值越小 颜色就越暗
中间一层
每个像素连接出来的宽度
最外一层
高度
'''
# 获取图片的像素值 高 宽 像素3个颜色
print(img.shape) # (1392, 959, 3)
shape = img.shape
# 重置图片的大小 会把修改大小的图片
resize_img = cv2.resize(img, dsize=(500, int((500/shape[1]) * shape[0]))) # dsize 宽 高
cv2.imwrite('liqin.jpg', resize_img) # 保存修改大小之后的图片
# 显示图片
cv2.imshow('liqin', resize_img) # 设置显示窗口的名字(不能用中文) 要显示的图片
# 图片显示多长时间后自动关闭
# cv2.waitKey(5000) # 5s后自动关闭 等待5s 键盘输入 如果键盘输入 由键盘输入控制退出 没有输入等待5s自动关闭
# 直到键盘输入才关闭
cv2.waitKey(0) # 0的话就是无限等待 直到键盘输入
# 销毁窗口
cv2.destroyAllWindows()
3.人脸检测之检测一张人脸
我们就借用一下沁沁的照片哈
'''
进行人脸检测时
根据人脸的特征
haar抽取图片中的特征方式
把特征数据封装在文件中
python环境的安装包 ---》lib ---> site-packages --- cv2 --- data
将特征文件存放在于当前的py文件相同的目录下
'''
import cv2
img = cv2.imread('./liqin.jpg')
# 根据特征文件生成一个人脸检测器
face_detector = cv2.CascadeClassifier('./haarcascade_frontalface_alt.xml')
# 检测图片中的人脸
face_zones = face_detector.detectMultiScale(img)
print(face_zones)
# [[201 91 96 96]] 二维的
'''
[201 91 96 96] 检测到的人脸区域
x y 宽 高
因为一张图片中可能包含好几个人脸 每个人脸都是一维的数据
'''
# 获取人脸区域
for x, y, w, h in face_zones:
# 用一个矩形把人脸区域圈起来
'''
img, 要圈中的图片
pt1, 左上角的坐标点
pt2, 右下角的坐标点
color, 线的颜色 [蓝 绿 红]
thickness=None 线宽
'''
cv2.rectangle(img, pt1=(x, y), pt2=(x + w, y + h), color=[0,0,255], thickness=2)
# 显示图片
cv2.imshow('liqin', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
结果为:
4.人脸检测之检测多张人脸
以爱因斯坦参加的索尔维会议照为例
'''
检测多张人脸
'''
import cv2
# 1.读取图片
img = cv2.imread('./suoerwei1.jpg')
# 设置人脸识别器
face_detector = cv2.CascadeClassifier('./haarcascade_frontalface_alt.xml')
# 通过人脸检测器 检测图片中的人脸区域
'''
scaleFactor
缩放比例 默认是1.3 数据是要大于1 的
实现人脸检测时 要扫描每个区域 规定的起始尺寸 根据scalefactor进行缩放
缩放尺寸越小 检测出来的人脸越多
minNeighbors
最少邻居 如果检测出来一张人脸 需要在人脸附近偏移几次 返回的都是人脸
这个才把人脸返回
值越大 人脸检测要求就越高
'''
face_zones = face_detector.detectMultiScale(img, scaleFactor=1.02, minNeighbors=6)
print(face_zones)
# 圈中人脸
for x, y, w, h in face_zones:
cv2.rectangle(img, pt1=(x, y), pt2=(x+w, y+h), color=[0,0,255],thickness=2)
# 显示图片
cv2.imshow('suoerwei', img)
cv2.waitKey(0)
cv2.destroyAllWindows()
结果为:
注意:在做人脸检测时, 检测出来的人脸与图片的像素清晰度也是有关系的, 模糊的图片检测的话会有误差的
猜你喜欢
- 2024-10-02 OpenCV(10)——几何变换之缩放(opencv图像几何变换)
- 2024-10-02 OpenCV:图像旋转与缩放(opencv mat旋转)
- 2024-10-02 讲实话,我会Python之后!我都不屑用PS了!Python抠图太方便了!
- 2024-10-02 [OpenCV实战]51 基于OpenCV实现图像极坐标变换与逆变换
- 2024-10-02 使用opencv实现深度学习的图片与视频的超分辨率
- 2024-10-02 使用OpenCV和python自动捕捉微笑的自拍(Python完整实现)
- 2024-10-02 如何用Python和OpenCV进行图像识别,实战教程
- 2024-10-02 基于OpenCV对神经网络预处理人脸图像的快速指南
- 2024-10-02 Java,OpenCV,分割图像,提取图像RGB、图像放大缩小、图像裁剪
- 2024-10-02 OpenCV实现图像缩放不失真(opencv图像resize)
你 发表评论:
欢迎- 最近发表
-
- 印度IT咨询公司Infosys 获得谷歌5亿美元大单
- 印度信息技术巨头Infosys对地球观测初创公司GalaxEye进行战略投资
- 你没见过的分库分表原理解析和解决方案(二)
- 安装MySQL(绿联nas安装mysql)
- SpringBoot数据库管理 - 用Liquibase对数据库管理和迁移?
- 一个轻量级 Java 权限认证框架,Sa-Token 让鉴权变得简单、优雅!
- 高效使用Java构建工具,Maven篇|云效工程师指北
- Java,screw,生成简洁好用的数据库表结构(html、doc、md)文档
- SpringBoot数据库操作的应用(springboot如何操作数据库)
- Mac Docker环境,利用Canal实现MySQL同步ES
- 标签列表
-
- ifneq (61)
- 字符串长度在线 (61)
- googlecloud (64)
- flutterrun (59)
- 系统设计图 (58)
- powershellfor (73)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- qcombobox样式表 (68)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)