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]]
在这里插入图片描述

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值