从今天开始,由我,星辰,来为大家分享一些我在AI学习道路上的一些收获和感想。之前思索了很久,看了很多大佬写的博客,自己也一直想写关于自己的所得所学,但多次写到一半,便不由自己删除,一方面苦于自己的文笔无法实现我真正想表达的,另一方面则是自己与其他大佬们还有很大差距,不敢妄言,但思来想去,还是想写,不然永远是没长进,尤其是表达方面,因而借着百度AI自学道路上面,决定开启属于自己的博客之旅,期间的一些代码构成也参考了一些博客中其他大佬的思想和结构,大部分是由自己总结的,因而虽不说能讲出个头头是道出来,但至少我相信能让读者有一些收获和产生一些共鸣的,有表达不对的地方,希望大家多多包涵、提提意见,晨某感激不尽。话不多说,开启星辰的第一段学习之旅——百度AI:从入门到放弃(1)
知识储备:(Python专场)
1. 熟悉百度AI平台,了解开放AI服务功能
2. 熟悉了解paddlepaddle基本框架思路
3. 对人工智能有一定的基础了解
4. 有一定python语言基础 (这里小编推荐的是Pycharm编译器)
项目一:动物识别AI调用
一、导入相关库
# coding= utf-8
import requests
import base64
# coding=utf-8 作为pycharm项目添加注释所要导入的识别“中文”步骤
import requests 作为获取网页响应的核心关键包
import base64 作为图片处理的核心处理包
二、 获取百度提供token值,以便获取AI接口
api_id = '……'
api_key = '……'
secret_key = '……'
url = 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=' + str(api_key) + '&client_secret=' + str(secret_key)
res = requests.get(url).text
a = eval(res)
access_token = a['access_token']
print(access_token)
上面所讲api_id、api_key、secret_key皆为申请百度AI接口所提前申请到的参数值,只需要登陆网站ai.baidu.com 注册所需要的信息服务资料即可,对于为何要获取token值,你可以把它理解成申请服务的统一格式,具体原因请查阅百度官网相关文档。
# 利用access_token做一些事情
animal = 'https://aip.baidubce.com/rest/2.0/image-classify/v1/animal?access_token=' + str(access_token)
header = {
'Content-Type' : 'application/x-www-form-urlencoded'
}
data = {}
animal 值为具体对获得的token值进行使用,获取百度动物识别接口权限
hearder 为申请访问的访问来源编值,具体知识可以参考python爬虫相关知识
data{}定义一种格式
with open('animal.jpg', 'rb') as f:
image = base64.b64encode(f.read())
# encode,decode 要学会熟练应用
data["image"] = str(image).encode('utf-8')
res2 = requests.post(url=animal,data=data, headers=header).text
for each in eval(res2)['result']:
print each['name'], '\t相似度:', each['score']
然后打开open具体你要检测的动物图片,小编建议放在同一个工程下,这样可以直接使用相对路径进行调用。
image = 进行对获得图片进行b64处理
接下来将改变后的图片格式依次进行格式化处理,然后post animal 之前的百度动物识别服务网站,获得效果。
这是我传入一张斑马图所得到的结果案例。
好了,大家是不是有点搞懂这些玩意儿了呢,欢迎大家私戳博主进一步讨论哈~