百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Python编程 - 基于OpenCV实现人脸识别(实践篇)爬虫+人脸识别

itomcoil 2025-01-29 16:13 30 浏览

一.案例概述

本案例需要一定的Python编程基础并掌握OpenCV基本使用。
时间仓促:初略编写文档

效果如下:

开发环境:

操作系统:Windows 10

开发工具:PyCharm 2019.2版本

python版本:3.6.7

计算机视频库包:
opencv_contrib_python-4.1.0.25-cp36-cp36m-win_amd64.whl

算法支持包:numpy(安装opencv默认安装numpy)

下载地址:

Python3.6.7:

Download Python?www.python.org

Pycharm工具:

Download PyCharm: Python IDE for Professional Developers by JetBrains?www.jetbrains.com

第三方包下载:

opencv-contrib-python?pypi.org

二.编写案例准备资源:

准备工作:

 1.开发环境、开发工具及第三方包准备完善并创建空项目。
 2.准备一些个人的图片(或者通过代码保存个人面部存入本地)要求:图片名称有一定规律
 3.爬虫文件 - 爬取明星照片并存储本地
 4.将明星图片和个人图片通过opencv处理保存面部图片
 5.开始编写人脸识别的代码

三.代码编写顺序

一.爬虫代码直接下载运行:点击下载链接:
https://pan.baidu.com/s/1BNzSQ2Xk9GkYslhwKXLYSQ 提取码: qmy1
二.安装python爬虫需要的第三方包

  • requests(用户网络访问)
  • beautifulsoup4(用户数据结构解析)
  • pypinyin(用于中文转换为拼音)

三.运行python爬虫代码

四.将图片转换为面部图片进行存储

# 获取小头像信息
import cv2
import os
# 图片张数变量
def read_image():
    dirs = os.listdir("d_img")
    for j,dir in enumerate(dirs):
        print(dir)
        # 判断是否有存储头像的路径
        file_path = "x_face/%s"%str(dir);
        if not os.path.exists(file_path):
            os.makedirs(file_path);
            pass
        num = 0;
        for i in range(0,20):
            image = cv2.imread('d_img/%s/%d.jpg'%(dir,i))
            gray = cv2.cvtColor(image,code = cv2.COLOR_BGR2GRAY);
            # 数据参数
            face_detector = cv2.CascadeClassifier("haarcascade_frontalface_alt.xml");
            # [3]进行数据对比:minNeighbors = 每一个目标至少要被检测 -整数
            face_01 = face_detector.detectMultiScale(gray, minNeighbors=4);
            # 绘制矩形人脸检测
            print("第%d张图片===:"%i,face_01)
            print(type(face_01))
            if isinstance(face_01,tuple):
                print("没有检查的头像")
                pass
            else:
                print("****有检查的头像****")
                for x, y, w, h in face_01:
                    # time.sleep(10)
                    x_face = gray[y:y + h, x:x + w];
                    x_face = cv2.resize(x_face,dsize=(200,200));
                    bo_photo = cv2.imwrite("%s\%d.jpg" % (file_path, num), x_face);
                    print("保存成功:%d" % num)
                    pass
                num+=1;
                pass
            pass
    pass
if __name__ == '__main__':
    read_image();
    pass

运行结果 - 生产以下文件:



五.人脸识别 - 主代码

# 人脸识别 - 主代码
import cv2
import os
import time
import numpy as np;
# 图片张数变量
def Get_x_faces():
    dirs = os.listdir("x_face")
    print(dirs)
    X = []# 
    Y = []# 
    for j,dir in enumerate(dirs):
        for i in range(0,9):
            image = cv2.imread('x_face/%s/%d.jpg'%(dir,i))
            gray = cv2.cvtColor(image,code = cv2.COLOR_BGR2GRAY);
            print("读取",gray.shape)
            # NoneType  ndarray
            if len(str(image))!=0:
                print("加入。。。。")
                X.append(gray)
                Y.append(j)
                pass
    return [X,Y,dirs]
    pass

if __name__ == '__main__':
    X,Y,dirs = Get_x_faces();
    print("X=",X)
    print("Y=",Y)
    print("dirs=",dirs)
    #asarray都可以将结构数据转化为ndarray
    X = np.asarray(X);
    Y = np.asarray(Y);
    # 产生一个随机数 -
    index = [i for i in range(0,len(X))];
    print(index)
    #现场修改序列,改变自身内容。(类似洗牌,打乱顺序)
    np.random.shuffle(index);
    print("***********",index)
    # 打乱顺序 :相同规则打乱
    X = X[index]
    Y = Y[index]
    print("88888888",Y)
    # 训练数据
    print("训练数据为:",len(X),len(Y))
    X_train = X[:len(X)]
    Y_train = Y[:len(Y)];
    print("800000",Y_train)
    # 算法Eigen 特征的意思
    # 主成分分析(PCA)——Eigenfaces(特征脸)——函数:cv2.face.EigenFaceRecognizer_create
    model = cv2.face.EigenFaceRecognizer_create();
    print(model)
    # 算法学习
    print("算法学习", len(X_train), len(Y_train));
    model.train(X, Y);
    print("已经学会了数据。。。。")
	# 测试数据
    # X_test, Y_test = X[-5:], Y[-5:];
    # 开始验证
    # for data in X_test:
    #     # print(data)
    #     result = model.predict(data);
    #     print("=================")
    #     print(result)
    #     print(dirs[result[0]])
    #     pass

    Video_face = cv2.VideoCapture(0);
    face_detector = cv2.CascadeClassifier("haarcascade_frontalface_alt.xml")
    # while循环调取视频图形
    while True:
        flag,frame = Video_face.read();
        gray = cv2.cvtColor(frame,code=cv2.COLOR_BGR2GRAY);
        faces = face_detector.detectMultiScale(gray,1.3,5);

        if isinstance(faces, tuple):
            print("没有检查的头像")
            pass
        else:
            print("有头像了。。。。")
            # for循环遍历数据
            for x, y, w, h in faces:
                cv2.rectangle(frame, pt1=(x, y), pt2=(x + w, y + h), color=[0, 0, 255], thickness=2);
                face = gray[y:y + h, x:x+w];
                print("===]]]", face.shape)
                face_1 = cv2.resize(face, dsize=(200, 200));
                print("=================")
                print(face_1.shape)
                # 开始对比
                print("~~~~"*20)
                print(" 参数为:",face_1.shape);
                result = model.predict(face_1);
                print("对比返回结果:", result)
                print('该人脸是:', dirs[result[0]])
                a1 = dirs[result[0]]
                if result[1]<1600:
                    a1 = "NO"
                    pass
                cv2.putText(frame, a1, (x, y), cv2.FONT_ITALIC, 1, [0, 0, 255], 2);
                pass
            pass
        cv2.imshow('face', frame)
        cv2.waitKey(100)
        pass
    video.release()
    cv2.destroyAllWindows();
    pass

大功告成

相关推荐

《Queendom》宣布冠军!女团MAMAMOO四人激动落泪

网易娱乐11月1日报道据台湾媒体报道,南韩女团竞争回归的生死斗《Queendom》昨(10/31)晚播出大决赛,并以直播方式进行,6组女团、女歌手皆演唱新歌,并加总前三轮的赛前赛、音源成绩与直播现场投...

正确复制、重写别人的代码,不算抄袭

我最近在一篇文章提到,工程师应该怎样避免使用大量的库、包以及其他依赖关系。我建议的另一种方案是,如果你没有达到重用第三方代码的阈值时,那么你就可以自己编写代码。在本文中,我将讨论一个在重用和从头开始编...

HTML DOM tr 对象_html event对象

tr对象tr对象代表了HTML表格的行。HTML文档中出现一个<tr>标签,就会创建一个tr对象。tr对象集合W3C:W3C标签。集合描述W3Ccells返回...

JS 打造动态表格_js如何动态改变表格内容

后台列表页最常见的需求:点击表头排序+一键全选。本文用原生js代码实现零依赖方案,涵盖DOM查询、排序算法、事件代理三大核心技能。效果速览一、核心思路事件入口:为每个<th>绑...

连肝7个晚上,总结了66条计算机网络的知识点

作者|哪吒来源|程序员小灰(ID:chengxuyuanxiaohui)计算机网络知识是面试常考的内容,在实际工作中经常涉及。最近,我总结了66条计算机网络相关的知识点。1、比较http0....

Vue 中 强制组件重新渲染的正确方法

作者:MichaelThiessen译者:前端小智来源:hackernoon有时候,依赖Vue响应方式来更新数据是不够的,相反,我们需要手动重新渲染组件来更新数据。或者,我们可能只想抛开当前的...

为什么100个前端只有1人能说清?浏览器重排/重绘深度解析

面试现场的"致命拷问""你的项目里做过哪些性能优化?能具体讲讲重排和重绘的区别吗?"作为面试官,我在秋招季连续面试过100多位前端候选人,这句提问几乎成了必考题。但令...

HTML DOM 介绍_dom4j html

HTMLDOM(文档对象模型)是一种基于文档的编程接口,它是HTML和XML文档的编程接口。它可以让开发人员通过JavaScript或其他脚本语言来访问和操作HTML和XML文档...

JavaScript 事件——“事件流和事件处理程序”的注意要点

事件流事件流描述的是从页面中接收事件的顺序。IE的事件流是事件冒泡流,而NetscapeCommunicator的事件流是事件捕获流。事件冒泡即事件开始时由最具体的元素接收,然后逐级向上传播到较为不...

探秘 Web 水印技术_水印制作网页

作者:fransli,腾讯PCG前端开发工程师Web水印技术在信息安全和版权保护等领域有着广泛的应用,对防止信息泄露或知识产品被侵犯有重要意义。水印根据可见性可分为可见水印和不可见水印(盲水印)...

国外顶流网红为流量拍摄性侵女学生?仅被封杀三月,回归仍爆火

曾经的油管之王,顶流网红DavidDobrik复出了。一切似乎都跟他因和成员灌酒性侵女学生被骂到退网之前一样:住在950万美元的豪宅,开着20万美元的阿斯顿马丁,每条视频都有数百万观看...人们仿佛...

JavaScript 内存泄漏排查方法_js内存泄漏及解决方法

一、概述本文主要介绍了如何通过Devtools的Memory内存工具排查JavaScript内存泄漏问题。先介绍了一些相关概念,说明了Memory内存工具的使用方式,然后介绍了堆快照的...

外贸独立站,网站优化的具体内容_外贸独立站,网站优化的具体内容有哪些

Wordpress网站优化,是通过优化代码、数据库、缓存、CSS/JS等内容,提升网站加载速度、交互性和稳定性。网站加载速度,是Google搜索引擎的第一权重,也是SEO优化的前提。1.优化渲染阻塞。...

这8个CSS工具可以提升编程速度_css用什么编译器

下面为大家推荐的这8个CSS工具,有提供函数的,有提供类的,有提取代码的,还有收集CSS的统计数据的……请花费两分钟的时间看完这篇文章,或许你会找到意外的惊喜,并且为你的编程之路打开了一扇新的大门。1...

vue的理解-vue源码 历史 简介 核心特性 和jquery区别 和 react对比

一、从历史说起Web是WorldWideWeb的简称,中文译为万维网我们可以将它规划成如下的几个时代来进行理解石器时代文明时代工业革命时代百花齐放时代石器时代石器时代指的就是我们的静态网页,可以欣...