python+tkinter百度云人脸识别可视化小工具

首先看效果图

小工具基于百度云人脸识别api制作,可视化操作。

首先申请百度云的账号,不用本菜鸟多说,

记住里面的appid,apikey secretkey

百度技术文档里找V3的说明

人脸检测的文档

https://cloud.baidu.com/doc/FACE/Face-Detect.html

人脸对比的文档

https://cloud.baidu.com/doc/FACE/Face-Match.html#Face-Match

需要获取 “Access Token

方法如下

通过requests的post方法可获取access_token值,30天有效期,API_Key,Secret_Key值上面已获得,直接使用

url = 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id={}&client_secret={}'.format(API_Key,Secret_Key)
header={'Content-Type':'application/json; charset=UTF-8'}

def get_access_token():#获取 access_token
    res = requests.post(url).content.decode('utf-8')
    res=json.loads(res)
    if 'error' in res:
        print('解析失败')
    else:
        access_token=res['access_token']
        # print(access_token)
        return access_token

接下来测试图片信息

如果是本地图片,必须对图片进行base64编码

这是图片检测的请求参数

参数必选类型说明
imagestringbase64编码后的图片数据,需urlencode,编码后的图片大小不超过2M
max_face_numuint32最多处理人脸的数目,默认值为1,仅检测图片中面积最大的那个人脸
face_fieldsstring包括age,beauty,expression,faceshape,gender,glasses,landmark,race,qualities信息,逗号分隔,默认只返回人脸框、概率和旋转角度
base64编码方法如下
def trans_base64(path):# 对图片进行base64编码
    with open(path,'rb') as f:
        data = f.read()
        encodestr = base64.b64encode(data)  # 得到 byte 编码的数据
        s=str(encodestr, 'utf-8')
        # print(s)
        return s

def check_img(flag,path):#面部识别
    cli=AipFace(AppId,API_Key,Secret_Key)
    image, image_type='',''
    if flag=='1':
        image=path
        image_type = 'URL'
    elif flag=='2':
        image=trans_base64(path)
        image_type = 'BASE64'
    options={}
    options['face_field']='age,beauty'
    options['max_face_num']=1
    options['face_type']='LIVE'
    res=cli.detect(image,image_type,options)
    print(res)
    if res['error_code']==0:
        print('读取成功')
        face_num=res['result']['face_num']
        face_age=res['result']['face_list'][0]['age']
        face_beaty=res['result']['face_list'][0]['beauty']
        print('人脸数量',face_num)
        print('人脸年龄',face_age)
        print('颜值',face_beaty)
        return face_num,face_age,face_beaty
    else:
        print('读取失败')

输出结果

测试用图片

输出json数据

{'error_code': 0, 'error_msg': 'SUCCESS', 'log_id': 10545051510, 'timestamp': 1538189699, 'cached': 0, 'result': {'face_num': 1, 'face_list': [{'face_token': '1474a50eec11226d009e0f35b031c6f4', 'location': {'left': 454.1082764, 'top': 247.6040649, 'width': 68, 'height': 73, 'rotation': 7}, 'face_probability': 1, 'angle': {'yaw': -4.729311466, 'pitch': -6.492731571, 'roll': 6.83347559}, 'age': 23, 'beauty': 66.00269318}]}}
读取成功
人脸数量 1
人脸年龄 23
颜值 66.00269318

检测还是挺准的

接下来测试2张图片对比

这是图片对比的请求参数

参数必选类型说明
imagesstring分别base64编码后的2张图片数据,需urlencode,半角逗号分隔,单次请求最大不超过20M
ext_fieldsstring返回质量信息,取值固定,目前支持qualities(质量检测)(对所有图片都会做改处理)
image_livenessstring返回的活体信息,“faceliveness,faceliveness” 表示对比对的两张图片都做活体检测;“,faceliveness” 表示对第一张图片不做活体检测、第二张图做活体检测;“faceliveness,” 表示对第一张图片做活体检测、第二张图不做活体检测;

代码如下

def check_face(flag1,flag2,path_1,path_2):#对比图片
    url='https://aip.baidubce.com/rest/2.0/face/v3/match'
    options=[{'image':'','image_type':'','face_type':'LIVE','quality_control':'LOW'},
             {'image':'','image_type':'','face_type':'LIVE','quality_control':'LOW'}]
    access_token=get_access_token()#得到access_token
    full_url=url+"?access_token=" + access_token
    if flag1=='1':#通道1 url
        if flag2=='1':#通道2 url
            options[0]['image']=''
            options[0]['image_type'] = 'URL'
            options[1]['image'] = ''
            options[1]['image_type'] = 'URL'
        elif flag2=='2':#通道2 base64
            options[0]['image']=''
            options[0]['image_type'] = 'URL'
            options[1]['image'] = trans_base64(path_2)
            options[1]['image_type'] = 'BASE64'
    elif flag1=='2':#通道1 base64
        if flag2=='1':#通道2 url
            options[0]['image']=trans_base64(path_1)
            options[0]['image_type'] = 'BASE64'
            options[1]['image'] = ''
            options[1]['image_type'] = 'URL'
        elif flag2=='2':#通道2 base64
            options[0]['image']=trans_base64(path_1)
            options[0]['image_type'] = 'BASE64'
            options[1]['image'] = trans_base64(path_2)
            options[1]['image_type'] = 'BASE64'
    res=requests.post(full_url,data=json.dumps(options),headers=header).content.decode('utf-8')
    print(res)
    res=json.loads(res)
    if res['error_code']==0:
        print('读取成功')
        face_res=res['result']['score']
        print('人脸相似度',face_res)
        return face_res
    else:
        print('读取失败')

 

测试用图片2张

                                                                 

输出结果

{"error_code":0,"error_msg":"SUCCESS","log_id":1019445001452,"timestamp":1538189910,"cached":0,"result":{"score":73.89654541,"face_list":[{"face_token":"1474a50eec11226d009e0f35b031c6f4"},{"face_token":"7120d4f0520d094d3bcd4a0c6da023d8"}]}}
读取成功
人脸相似度 73.89654541

 

 

 

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一个VB6的IDE插件(Addin),使用VB6的IDE直接设计Python的界面。 Python和VB都是能让人快乐的编程语言,我使用了Python之后,很多自己使用的工具都使用Python开发或改写了,因为最终实现的Python代码实在太短了(相比VB),有时候Python一行代码就可以实现VB一个函数的功能。 Python就是这种让人越用越开心的语言。 不过说实在,使用Python开发GUI界面还是麻烦了一些了,自带的标准库Tkinter使用起来非常简单,不过对于习惯了VB拖放控件完成界面设计的偶来说,还是不够人性化。TK也有一个工具叫GUI Builder,不过它使用Layout布局,不够直观,而且用起来很不爽。。 至于PyQt/wxPython等GUI库,尽管有可视化设计工具,但总感觉做一般的轻量级应用是杀鸡用牛刀, 而且不够环保,不够低碳,要带一个很大的库,需要目标机器上夜同样安装了PyQt/wxPython,做不了绿色软件。 所以最终的结果是我更喜欢Tkinter,用起来很简单,绿色环保,真正的跨平台,一个py文件到处运行(担心泄密就编译成pyc)。 很多人都认为TK的界面不够美观,不过我经过多次实验后发现导入Python自带的标准TTK主题库,界面非常Native,不输PyQt/wxPython。 此Addin默认启用TTK支持,也可选择关闭。 总而言之,轻量级GUI,TK+TTK足够。 使用此Addin,你可以不用写一句代码就可以生成一个完整可运行的Python的GUI界面,支持2.X和3.X。 安装方法:将压缩包解压到你希望的目录,然后执行Setup.exe完成注册插件过程,打开VB6就可以用了。 在VB窗体上设计完成界面后(你可以大胆的设置各控件的属性,Addin尽量将其翻译为tkinter的控件属性),点工具栏上的VisualTkinter(图标为一片羽毛),再点'生成代码'按钮,即可生成可运行的Python代码,可以拷贝至剪贴板或保存至文件。 一般情况下你可以不用再改变tkinter的控件属性,但是如果你熟悉tkinter,需要更多的控制,可以一一核对各属性,并且修改,再生成代码。 当然除了用来设计界面外,此ADDIN内置的各控件属性列表可以做为编程参考,比较完整,除了极少数我认为大多数人都不用的属性外,属性定义基本上是我从官方的tkinter文档直接翻译的。 如果还没有VB6,网上找一个VB6精简版即可,不到20M,小巧玲珑。 代码已经在Github上托管,更新的版本可以在这上面找到,需求也可以在上面提: https://github.com/cdhigh/Visual-Tkinter-for-Python

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值