python+opencv的图像学基础以及简单的人脸识别

python+opencv的图像学基础以及简单的人脸识别

一、列表

list(),int()都属于强制类型转化,将字符串转化为list列表
一维数组 a=[1 2 3 4 5 6]
a[4]=5
二维数组 b=[[1 2][3 4][5 6][7 8]]
b[1][1]=4
三维数组 c=[[[1 2][3 4]][[5 6][7 8]]]
c[1][1][1]=8

二、图像转字符画

目的:将图像转化按照列表格式输出

show_height=40#纵向打印字符数
show_width=40#横向打印字符数
ascii_char=list("$@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~<>i!lI;:,\"^`'. ")
print(ascii_char[10])
#读取图片
pic=cv2.imread("E:/Literature/material/121398.jpg")
print(type(pic))
#<class 'numpy.ndarray'>
#图像灰度化
gray=pic[:,:,0]*0.2+pic[:,:,1]*0.7+pic[:,:,2]*0.1
print(gray)
print(len(gray))#长
print(len(gray[0]))#宽
pic_height,pic_width,pic_c=pic.shape
print(pic_height)
print(pic_width)
for i in range(show_height):
    y=int(i*pic_height/show_height)#获取真实图片上某个像素点的纵坐标
    text = ""
    for j in range(show_width):
        x = int(j * pic_width / show_width)  # 获取真实图片上某个像素点的横坐标
        text+=ascii_char[int(gray[y][x]/256*len(ascii_char))]
    print(text)
#结果
vvccvvvuvvvvvqcvvvvvcvvvvccccccvvvvvvvvv#每行四十的字符
uvvvuuuuuuvvuUXuvcvvvvvvcvccvcvvvvvvvvvv
uuuuuuuvuuuuv1fvvvvvvvvvvvcvvvvvvvvvvvuu
uunuuuuuuuuucYjuuuuuuuuuuuuvuuuuuuuuuuuv
nnnnnnnnnuuuucJunnuununuuuuucLuuunuunnun
xnnxnnnnnnqnJYuznxnnnnnunnnnQ_nnnuuunnnn
xxxxxxxxxxYxrcmx/xxxxxnnnnxnvvunnxnxxxxx
rrrrrrrrrr0cZxM{
|rxxxxxxxxxxUz|xxrxxnxxx
jrjjrrrjjrkwJfOUUrnrrrrrrrrrLoz0rxrrxrrr
fjfjfjjjjqqUzaf*OoUjrjjjrrj10czLrrrrrrrr
ffffffffj*hU$Yjcr/cjjjjjjjrmnXxUxjjjjjjj
/ttttttttokQOnppJ@O|jffffjrbtcvprjffjjff
///////tWq%0zU#mbkzYfttttf/pz%80btCftfff
\\\\\/\|b8WCXXr0mQXtt//tt\CqqptxZbuftttt
|||\|\|\hMCYUjnjjrct\/\/f\CdWpdrZQ*|/\\\
(((||||\QdkYXxfcnxv\\\\\l)ok$%cYOpkQ/\\|
))((((((mZbcYYmaL\c\||||-X@d8wvuuQ0n\|||
11)))))(qQXXYY0uXfX((((urcYbWpznXUuz)(((
{
{
{
11111mzUUUJcccnY11j/{
|qbpMWYvOqvz()))
}{
{
{
{
{
1{
OUYOQXuz0uY)?twpXMqoLBXcXUZJ(111
}}}}}}}1OYm0Jz[t/tzJ)cX#vcrmp@rxzUcq1{
{
{

[[[[[[[Zz@Y0CupdpLwf*z*p000zmatqJJXC{
[}}
]]]][]]ZY|*%pj(txuJ)vh/fC.jtrLqZtx0n/[[[
-?????-ZO$QwzMZjjbobvXrf)xxuxbkn#fJxU}]]
------]8hWLZcr\cxrZvJrXL@xBUz0JMqcn/0[??
_--_---wcOcQntJ(vnmcCc#8JOJYcUfCr08CdX--
___+[f/QvLUJJv@aYtqrtjjOo\0CXrj0xJOckc_-
_+_~zLO0uuJYx\znr|wrUX\+qUJOrL0puUzvqr_-
|fCYJo#YxjXUqfXrx\QnC|\|Y}n/j\WujzxYmp~~
8cqB8/mOrOXYXbQc|{
n0r1|(t\fn/tJn(uUmjZi~
XWmjY/qcoQYznr){
rYr|txttuCXxzQZJf[{
1/cq}
XQzUpCZzr?(Ltr))(/u/jxz0un(rftt\mvffbtU+
QadzLnaZ$0vJnWLut|Z|tOdJnxh%8&d)%&|(1jt>
0JCxM%zvWmvLnu|bjfznrjfx|nzf|tx}QjLnXQ/k
(YbjMUQvvmxOnfX[ttXfxjtva}<aY\QtCj/n|Lx)
UXXXkQUXcOnLnjujfjXxnrcj(0j[OQO/Yj)Qf0UJ
z!cYrcXcYLjJut*&*xjx/xC[\hba{
bUnXfmUJLCc
v<vCjuCzzCrJxz--mcrn\xYrn@J/xczXxf++Zxdr
v(uxxnJz(CjYju$@Yux/f/XtfxwJQUrQt{
$1v\Qj
cxzu}zYXcUrUtv@@$jfXnuYUdQCZCCuv|u&*c)Of

三、opencv的简单使用

OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉和机器学习软件库,
可以运行在Linux、Windows、Android和Mac OS操作系统上。
它轻量级而且高效——由一系列 C 函数和少量 C++ 类构成,
同时提供了Python、Ruby、MATLAB等语言的接口,
实现了图像处理和计算机视觉方面的很多通用算法。
3.1显示图片

import cv2
#绝对路径
img=cv2.imread('E:/Literature/material/personal/12.png')
#相对路径
cv2.imread(./image/12.png)
#打印图像数组
print(img)
#打印图像长宽和像素#bgr格式
print(img.shape)
cv2.imshow("student",img)
#让cv2的类型进行等待,不会闪退,我们可以去设置时间让图像延迟关闭,数字代表停留时间,ms级
#括号里写等待时间
cv2.waitKey()
#释放资源
cv2.destroyAllWindows()

运行结果
在这里插入图片描述
3.2改变图像大小和黑白图

import cv2
img=cv2.imread('E:/Literature/material/personal/2.jpg')#绝对路径
#改变图像大小和黑白图
gray=cv2.cvtColor(img,code=cv2.COLOR_BGR2GRAY)
#将图像进行黑白图转换
#三维数字变为二维数组
cv2.imshow("student",gray)
cv2.waitKey()
cv2.destroyAllWindows()
#更改图像大小
imgresize=cv2.resize(gray,dsize=(222,222))
cv2.imshow("student_resize",imgresize)
cv2.waitKey()
cv2.destroyAllWindows()

运行结果
在这里插入图片描述
在这里插入图片描述
3.3图像剪裁

import cv2
img=cv2.imread('E:/Literature/material/personal/2.jpg')#绝对路径
#剪裁
#将图像从横范围第一个像素,取到222,纵坐标从1取到222.
imgjc=img[:222,:222]
cv2.imshow("imgjc",imgjc)
cv2.waitKey()
cv2.destroyAllWindows()
#图片的切片使用
#将图像从横范围111,取到222,纵坐标从1取到222.
imgqp=img[111:222,:222]
cv2.imshow("imgqp",imgqp)
cv2.waitKey()
cv2.destroyAllWindows()

运行结果
在这里插入图片描述
在这里插入图片描述

四、简单的人脸识别

import cv2
img=cv2.imread('E:/Literature/material/personal/2.jpg')#绝对路径
#人脸的识别,保证人脸图片清晰,要尽量选择正脸进行识别
#导入cv2中人脸特征数据的数据包,里面都是人脸特征数据
#在python环境中,有已经集成好的训练文件,位置lib—>site-packages—>cv2—>data—>haarcascade_frontalface_alt.xml
#获取你的特征数据包
face_date=cv2.CascadeClassifier("E:/python3.6.8/Lib/site-packages/cv2/data/haarcascade_frontalface_alt.xml")
#图像,缩放距离,最小间距
faces=face_date.detectMultiScale(img,scaleFactor=1.1,minNeighbors=5)
#随着返回着二维数组里外维度下元素的个数表示识别人脸的个数
print(faces)#表示距离图像边缘的距离
for x,y,w,h in faces:
#画矩形
#人脸图像,人脸方框的初始位置,人脸方框的末尾坐标,边框颜色
cv2.rectangle(img,pt1=(x,y),pt2=(x+w,y+h),color=[255,0,0])
cv2.imshow("faces",img)
cv2.waitKey(0)
cv2.destroyAllWindows()

运行结果
[[ 90 137 62 62]]
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/114574.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • YOLO3训练自己数据(超详细步骤)

    YOLO3训练自己数据(超详细步骤)须知:对于占比较小的目标检测效果不好,虽然每个格子可以预测多个boundingbox,但是最终只选择IOU(预测的矩形框和真实目标的交集与并集之比)最高的boundingbox作为物体检测输出,即每个格子最多只预测出一个物体。当一个格子中包含多个物体时,如鸟群等,却只能检测出其中一个。另外,YOLO对车牌识别的效果一般。一:下载YOLO3项目gitclonehttps://githu…

  • TCP拥塞控制算法(Tahoe/Reno/Newreno)

    TCP拥塞控制算法(Tahoe/Reno/Newreno)TCP拥塞控制算法(Tahoe/Reno/Newreno)前言TCP(TransmissionControlProtocol),传输控制协议,是目前__Internet__上最重要的一个通信协议之一,其作用是对数据的传输进行一定的控制;而拥塞控制算法又是TCP中最重要的一个算法之一,接下来我们先来了解一下基本概念,再来详细介绍3个协议中的拥塞控制算法以及他们之间的区别。前期知识储备及名词…

  • mysql删除表数据及其关联数据_MYSQL中delete删除多表数据与删除关联数据

    mysql删除表数据及其关联数据_MYSQL中delete删除多表数据与删除关联数据在mysql中删除数据方法有很多种,最常用的是使用delete来删除记录,下面我来介绍delete删除单条记录与删除多表关联数据的一些简单实例。1、deletefromt1where条件2、deletet1fromt1where条件3、deletet1fromt1,t2where条件4、deletet1,t2fromt1,t2where条件前3者是可行的,第…

  • Mysql Workbench使用教程

    Mysql Workbench使用教程<1>MySQLWorkbenchMySQLWorkbench为数据库管理员、程序开发者和系统规划师提供可视化的Sql开发、数据库建模、以及数据库管理功能。<2>.MySQLWorkbench的下载和安装(1)安装最新MySql时,有是否安装MySqlWorkbench的选项,可选择安装。(2)可以独立安装MySqlWorkbench…

  • 学了元件作用域,我终于对JMeter开窍了

    学了元件作用域,我终于对JMeter开窍了

    2020年11月20日
  • 不错的BLOG和论坛[通俗易懂]

    不错的BLOG和论坛[通俗易懂]高手的博客阿虚的电子小屋http://hi.baidu.com/aokikyon(从单片机到嵌入式linux都有研究)XY嵌入式Linux  http://blog.chinaunix.net/group/group_1488.html(嵌入式内核研究)嵌入式系统开发Linux+ARMhttp://blog.chinaunix.net/u2/79779/index.html(

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号