百度AI攻略:地标识别

1.需求及方案:

在我以前的一个帖子https://ai.baidu.com/forum/topic/show/943365 里面讲了怎么通过图像分割来旅游。

这一次我要说一下怎么通过地标识别+百度百科带大家来看遍/认识天下名胜。

2.平台接入

地标识别接入网址:https://console.bce.baidu.com/ai/#/ai/imagerecognition/overview/index

具体接入方式比较简单,可以参考我的另一个帖子,这里就不重复了:

http://ai.baidu.com/forum/topic/show/943327

3.地标识别调用攻略(Python3)

3.1首先认证授权:

在开始调用任何API之前需要先进行认证授权,具体的说明请参考:

http://ai.baidu.com/docs#/Auth/top

具体Python3代码如下:

# -*- coding: utf-8 -*-

#!/usr/bin/env python

import urllib

import base64

import json

#client_id 为官网获取的AK, client_secret 为官网获取的SK

client_id =【百度云应用的AK】

client_secret =【百度云应用的SK】

#获取token

def get_token():

    host = 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=' + client_id + '&client_secret=' + client_secret

    request = urllib.request.Request(host)

    request.add_header('Content-Type', 'application/json; charset=UTF-8')

    response = urllib.request.urlopen(request)

    token_content = response.read()

    if token_content:

        token_info = json.loads(token_content)

        token_key = token_info['access_token']

    return token_key

3.2 接口调用:

详细说明请参考:https://ai.baidu.com/docs#/ImageClassify-API/2c607890

说明的比较清晰,这里就不重复了。

大家需要注意的是:

API访问URL:https://aip.baidubce.com/rest/2.0/image-classify/v1/landmark

图片格式:Base64编码字符串,以图片文件形式请求时必填。(支持图片格式:jpg,bmp,png),图片大小不超过4M。最短边至少15px,最长边最大4096px。 注意:图片的base64编码是不包含图片头的

Python3调用代码如下:

#地标识别

#filename:图片名(本地存储包括路径)

def landmark(filename):

    request_url = "https://aip.baidubce.com/rest/2.0/image-classify/v1/landmark"


    # 二进制方式打开图片文件

    f = open(filename, 'rb')

    img = base64.b64encode(f.read())


    params = dict()

    params['image'] = img

    params['show'] = 'true'

    params = urllib.parse.urlencode(params).encode("utf-8")

    #params = json.dumps(params).encode('utf-8')


    access_token = get_token()

    request_url = request_url + "?access_token=" + access_token

    request = urllib.request.Request(url=request_url, data=params)

    request.add_header('Content-Type', 'application/x-www-form-urlencoded')

    response = urllib.request.urlopen(request)

    content = response.read()

    landmark=''

    if content:

        #print(content)

        content=content.decode('utf-8')

        #print(content)

        data = json.loads(content)

        #print(data)

        words_result=data['result']

        landmark=words_result['landmark']

        print ('地标:',landmark)


    return landmark

4.应用方案:

4.1 整体方案:

首先调用地标识别API对地标图片进行识别。

然后通过百度百科对地标的具体情况进行搜索,并将结果展示给客户。

4.2 具体实现代码:

# -*- coding: utf-8 -*-

#!/usr/bin/env python

import urllib

import base64

import json

#client_id 为官网获取的AK, client_secret 为官网获取的SK

client_id =【百度云应用的AK】

client_secret =【百度云应用的SK】

#获取token

def get_token():

    host = 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=' + client_id + '&client_secret=' + client_secret

    request = urllib.request.Request(host)

    request.add_header('Content-Type', 'application/json; charset=UTF-8')

    response = urllib.request.urlopen(request)

    token_content = response.read()

    if token_content:

        token_info = json.loads(token_content)

        token_key = token_info['access_token']

    return token_key

#地标识别

#filename:图片名(本地存储包括路径)

def landmark(filename):

    request_url = "https://aip.baidubce.com/rest/2.0/image-classify/v1/landmark"


    # 二进制方式打开图片文件

    f = open(filename, 'rb')

    img = base64.b64encode(f.read())


    params = dict()

    params['image'] = img

    params['show'] = 'true'

    params = urllib.parse.urlencode(params).encode("utf-8")

    #params = json.dumps(params).encode('utf-8')


    access_token = get_token()

    request_url = request_url + "?access_token=" + access_token

    request = urllib.request.Request(url=request_url, data=params)

    request.add_header('Content-Type', 'application/x-www-form-urlencoded')

    response = urllib.request.urlopen(request)

    content = response.read()

    landmark=''

    if content:

        #print(content)

        content=content.decode('utf-8')

        #print(content)

        data = json.loads(content)

        #print(data)

        words_result=data['result']

        landmark=words_result['landmark']

        print ('地标:',landmark)


    return landmark

from bs4 import BeautifulSoup

#通过百度百科获取地标的详细说明       

def get_baike_summary(itemname):

    url='https://baike.baidu.com/item/'+urllib.parse.quote(itemname)

    # 构建请求对象 

    headers = { 

        "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/66.0.3359.139 Safari/537.36" 

    } 

    request = urllib.request.Request(url, headers=headers) 

    # 发送请求 

    response = urllib.request.urlopen(request) 

    # 读取文件 

    content = response.read().decode('utf8')

    # 先构建一个soup对象     

    soup = BeautifulSoup(content, "lxml") 

    #获取描述

    summary = soup.find("div", attrs={"class": "lemma-summary"}).get_text()

    print (summary)

def get_landmark_more(filename):

    result=landmark(filename)

    get_baike_summary(result)


get_landmark_more('landmark1.jpg')

5 效果测试

以下是几个测试地标图片及返回结果。

地标: 埃菲尔铁塔

埃菲尔铁塔(法语:La Tour Eiffel;英语:the Eiffel Tower)矗立在塞纳河南岸法国巴黎的战神广场,于1889年建成,是当时世界上最高的建筑物。埃菲尔铁塔得名于设计它的著名建筑师、结构工程师古斯塔夫·埃菲尔,全部由施耐德铁器(现施耐德电气)建造。埃菲尔铁塔高300米,天线高24米,总高324米,铁塔是由很多分散的钢铁构件组成的——看起来就像一堆模型的组件。钢铁构件有18038个,重达10000吨,施工时共钻孔700万个,使用1.2万个金属部件,用铆钉250万个。除了四个脚是用钢筋水泥之外,全身都用钢铁构成,共用去熟铁7300吨。塔分三楼,分别在离地面57.6米、115.7米和276.1米处,其中一、二楼设有餐厅,第三楼建有观景台,从塔座到塔顶共有1711级阶梯。埃菲尔铁塔是世界著名建筑、法国文化象征之一、巴黎城市地标之一、巴黎最高建筑物。被法国人爱称为“铁娘子” 。埃菲尔铁塔2011年约有698万人参观,在2010年累计参观人数已超过2.7亿人,每年为巴黎带来15亿欧元的旅游收入。

[1]

地标: 胡夫金字塔

胡夫金字塔是古埃及金字塔中最大的金字塔。塔高146.59米,因年久风化,顶端剥落10米,现高136.5米,相当于40层大厦高。塔身是用230万块巨石堆砌而成,大小不等的石料重达1.5吨至160吨,塔的总重量约为684万吨,它的规模是埃及至今发现的110座金字塔中最大的。它是一座几乎实心的巨石体,成群结队的人将这些大石块沿着金字塔内部的螺旋上升通道往上拖运,然后逐层堆砌而成,十万多个工匠共用约20年的时间才完成的人类奇迹,当年埃菲尔铁塔还未建成时胡夫金字塔还曾是世界上最高的建筑物。

地标: 卢浮宫

卢浮宫(法语:Musée du Louvre)位于法国巴黎市中心的塞纳河北岸,位居世界四大博物馆之首。始建于1204年,原是法国的王宫,居住过50位法国国王和王后,是法国文艺复兴时期最珍贵的建筑物之一,以收藏丰富的古典绘画和雕刻而闻名于世。现为卢浮宫博物馆,占地约198公顷,分新老两部分,宫前的金字塔形玻璃入口,占地面积为24公顷,是华人建筑大师贝聿铭设计的。1793年8月10日,卢浮宫艺术馆正式对外开放,成为一个博物馆。卢浮宫已成为世界著名的艺术殿堂,最大的艺术宝库之一,是举世瞩目的万宝之宫。

通过测试发现识别的效果很好,速度很快,配合自动调取的百度百科的内容描述,效果非常的棒。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,875评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,569评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,475评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,459评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,537评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,563评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,580评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,326评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,773评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,086评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,252评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,921评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,566评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,190评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,435评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,129评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,125评论 2 352

推荐阅读更多精彩内容