python获取藏头诗内容_Watson使用指南(六)在微信公众号中实现识图作诗功能
本文章主要是写一下这个项目开发的过程及之间遇到的问题,作为记录,也希望以此为契机认识志同道合的朋友,一起学习交流。
目录:
概述
环境准备及相关账号申请
部署Python Flask应用到Bluemix
通过Bluemix认证公众微信号
识图作诗相关功能开发
总结
概述
本文将从一个开发人员角度,介绍如何使用Bluemix平台开发和部署Python Flask应用,如何通过Bluemix进行微信公众号认证,最后结合相关Watson服务,实现用户向公众号发送图片,后台识别图片并返回诗文的功能。
Bluemix
BLuemix是IBM公司推出的一个云平台服务,通过它不仅可以部署本地应用到云端,还可以调用BLuemix本身自带的强大的一系列服务来实现很多功能。
Watson
Watson是IBM公司推出的一系列认知计算服务,包括自然语言分类,情感分析,图像识别等等,我在本系列的前几期已经完成了可用Python实现部分的文档翻译,详见
微信公众平台
作为一个程序员,使用微信公众号,关注点就不仅仅是发送推文消息了,通过自己开发,来实现一些有趣的功能,做不同于一般的公众号才是我想要的。
环境准备及相关账号申请
注册BLuemix账号
申请地址:http://www.bluemix.net 在页面右上角点击注册,填写相关信息提交申请,Bluemix 会发一封确认邮件到注册邮箱,需要手工进入注册邮箱点击确认,才能成功注册。第一次登陆 Bluemix 控制台的时候,会要求创建工作空间,建议创建在悉尼或英国(虽然访问都很慢)。
安装CloudFoundry工具
通过该工具,可以在命令行使用CF相关命令进行与BLuemix之间的交互,包括部署,更新,查询。详见:http://docs.cloudfoundry.org/...
注册微信公众号
这个很简单,而且网上一搜很多,我在这里就不说了。
部署Python Flask应用到Bluemix
Python Flask
Python Flask 是基于Python的一种轻量级网络框架,便捷易用。这个应用中Flask仅仅起到传递参数的作用,对于Flask本身的使用不是很多。这就是说,你同样可以仅仅使用Python,因为Python本身也可以提供网络服务。
创建应用
在Bluemix首页点击创建应用,新的页面中会显示很多可创建的应用案例,下拉菜单找到Flask,创建,根据提示填写域名等信息。创建后根据页面提示下载模板代码到本地。
要想在bluemix下成功运行应用,至少需要有manifest.yml,requirements.txt,runtime.txt和app.py这四个文件。
manifest.yml
这是应用程序的基本配置信息,包括域名和主机名。是下载源码后默认的,不需要更改。
requirements.txt
这个文件中包含应用所需要的第三方依赖,比如我的应用里是这样的:
Flask
watson_developer_cloud
lxml
flask是Python网络框架。watson_developer_cloud用于调用Watson服务。lxml包用来爬取网络信息。
runtime.txt
该文件用来指定需要的Python版本
app.py
Python应用的脚本或源代码文件,我会在“识图作诗相关功能开发”做详细说明
部署应用
在本地进行应用的开发,并且本地调试和运行成功后就可以部署代码了。在bluemix上点击应用程序,在应用程序菜单选择“入门”,根据提示在本地命令行使用cf命令就可以成功push到BLuemix上。如果过程中遇到问题,可以通过
cf logs 应用程序名 --recent
来查看错误
创建并绑定服务
在Bluemix应用程序界面找到创建新服务,同创建应用程序一样,新界面会有很多服务可供选择。这里,我选择的是Visual Recognition服务来进行图片识别。创建新服务后,点击连接到现有应用程序,就OK了。关于服务的创建,具体参见Watson使用指南(五)
通过Bluemix认证公众微信号
在微信公众号页面打开开发者页面,进行服务器配置。需要注意的是令牌自己随意填写就好。
新建auth.py,根据微信官方的文档,获取相关参数:
token = '微信页面填写的令牌'
signature = request.args.get('signature', '')
echostr = request.args.get('echostr', '')
timestamp = request.args.get('timestamp', '')
nonce = request.args.get('nonce', '')
tmp = [timestamp, nonce, token]
tmp.sort()
tmp = ''.join(tmp)
if ( hashlib.sha1(tmp).hexdigest() == signature ):
return make_response(echostr)
push代码到Bluemix,在微信页面点击提交,显示提交成功,就完了通过Bluemix认证微信号。
识图作诗相关功能开发
顾名思义,识图作诗,就包括识图和作诗两个部分。用到三个文件,visual.py,translate.py,poem.py
visual.py
调用Watson服务,返回的是嵌套字典信息,可以转换成JSON格式然后提取信息。这里直接操作字典提取:
def VisualContent(url):
visualRecognition = VisualRecognitionV3('2016-05-20', api_key='创建服务后系统返回的api_key')
content = visualRecognition.classify(images_url = url)
images = content.get("images")
classifiers = images[0].get("classifiers")
classes = classifiers[0].get("classes")
res = classes[0].get("class")
return res
translate.py
Watson服务中有翻译服务,但是不支持英汉互译。而获取到的图片信息都是英文,显然不能直接去用英文来搜索相关诗文。于是我写了这个模块,直接在有道翻译的网页中获取翻译。
def Translate(word):
url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=http://www.youdao.com/'
key = word
data = {}
data['type'] = 'AUTO'
data['i'] = key
data['doctype'] = 'json'
data['xmlVersion'] = '1.6'
data['keyfrom'] = 'fanyi.web'
data['ue'] = 'UTF-8'
data['typoResult'] = 'true'
data = urllib.parse.urlencode(data).encode("utf-8")
content = urllib.request.urlopen(url, data).read().decode("utf-8")
json_content = json.loads(content)
res = json_content["translateResult"][0][0]['tgt'][:2]
return res
poem.py
最后一个部分,就是根据图片内容获得诗文信息了,简单的爬虫,用xpath直接
获得网页内容。
def MakePoem(word):
url_base = "地址"
key = word
url = url_base+key
res = requests.get(url)
res.encoding = 'utf-8'
#print(res.text)
root = etree.HTML(res.content)
items = root.xpath('//div[@class="sons"][2]/p[@style="margin-bottom:0px;"]')[0]
item = items.xpath('string(.)')
content = item.replace('\n','').replace(' ','')
length = len(content)
answer = content[:length-1]
return answer
其他
值得一提的是,微信公众号中的消息处理都是以xml格式封装的,所以在获取用户消息中,需要解析格式获取消息内容;同样,返回消息时,也要对内容封装后再返回用户。
总结
通过这几天微信后台的反馈来看,服务器不稳定,识别内容类别较少,爬取信息不稳定这三个因素经常导致用户会收到“暂时停止服务”的消息。
后期添加异常处理模块希望能使错误信息得到人性化反馈。
这是我的公众号,欢迎关注
python获取藏头诗内容_Watson使用指南(六)在微信公众号中实现识图作诗功能相关推荐
- python微信公众号翻译功能怎么用_Watson使用指南(七)在微信公众号中实现识图作诗功能...
本文章主要是写一下这个项目开发的过程及之间遇到的问题,作为记录,也希望以此为契机认识志同道合的朋友,一起学习交流. 目录: 概述 环境准备及相关账号申请 部署Python Flask应用到Bluemi ...
- Watson使用指南(六)在微信公众号中实现识图作诗功能
本文章主要是写一下这个项目开发的过程及之间遇到的问题,作为记录,也希望以此为契机认识志同道合的朋友,一起学习交流. 目录: 概述 环境准备及相关账号申请 部署Python Flask应用到Bluemi ...
- 在微信公众号中写html代码吗,微信公众号内容如何利用html编辑?
微信公众号内容如何利用html编辑?以下是小编整理的怎么利用html代码去更换微信公众号里的内容,有需要的朋友们请往下看具体怎么去操作的.以下内容供大家参考. 登录微信公众号 点击左侧分类的" ...
- 微信公众号中 JavaScript 获取用户周边的标志性建筑列表
微信公众号中 JavaScript 获取用户周边的标志性建筑列表 太阳火神的美丽人生 (http://blog.csdn.net/opengl_es) 本文遵循"署名-非商业用途-保持一致& ...
- 微信公众号代运营注意!公众号营销内容有新要求!做好微信公众号运营,需要规避什么?
大家好,我是企企宣创始人南则北. 近日,微信官方号微信公众平台运营中心发布了关于微信公众号营销内容合规规范的通知.此次通知,主要强调的是营销内容这一块,强调要遵守近期国家市场监督管理总局发布<互 ...
- python获取藏头诗内容_用Python作诗,生活仍有诗和远方
具体步骤: 使用爬虫爬取全唐诗,总共抓取了71000首. #使用urllib3的内置函数构建爬虫的安全验证,来应对网站的反爬虫机制 http = urllib3.PoolManager( cert_r ...
- 微信公众号中如何展开、隐藏内容
在第三方编辑器中,切换到HTML源码编辑模式. 输入以下代码: <details><summary style="text-align: center;"& ...
- python获取藏头诗_1_下载全国历代古诗
使用python 下载全国历代古诗 打开CMD 安装以下程序 pip install requests pip install lxml 以下是全部代码 import requests from lx ...
- Python 抓取微信公众号账号信息
搜狗微信搜索提供两种类型的关键词搜索,一种是搜索公众号文章内容,另一种是直接搜索微信公众号.通过微信公众号搜索可以获取公众号的基本信息及最近发布的10条文章,今天来抓取一下微信公众号的账号信息 爬虫 ...
最新文章
- proxmoxve打造云桌面_AIO攻略 | 桌面云是如何解决外设问题的?
- 技术:常见视频会议网络线路介绍
- What you should know about .so files
- 景切换的时候加上遮罩
- pacemaker+corosync
- 10.类的构造(1)
- laravel方法汇总详解
- 谁敢动英伟达的奶酪?AI芯片领域,这12家创业公司值得关注
- 维护 linux 服务器常用操作命令
- 利用 Aliyun OSS Nginx proxy module 实现OSS 图片处理回写功能
- Java系统架构的演化之路
- 基于Java实现的植物大战僵尸游戏
- 实况足球2015pc版
- 软件研发过程客观体检指标
- 消息: Automation 服务器不能创建对象
- 一篇经典的 Redis 面试资料「处女座笔记」「吐血推荐」...
- INVALID_PARAMETER 订单信息无法识别,建议联系卖家。 支付宝
- 用ECS做HexMap:利用RenderMesh为六边形涂色
- React pdf 电子书
- 全波形反演的深度学习方法: 第 4 章 基于正演的 FWI
热门文章
- 量具管理-GUI模板
- “浪姐”引爆股价 但芒果超媒真扛得动1300亿市值吗?
- Leetcode 792. 匹配子序列的单词数 C++
- C++ string万能类型转换
- EQ均衡器中的G 、Q、FC与截止频率知识
- 婚姻匹配算法(图实现)
- mysql 5.7.20 my.cnf_mysql 5.7 的 /etc/my.cnf
- 图像处理函数——roicolor、regionprops、padarray、nlfilter
- L99PM62GXP_带LIN和高速CAN的电源管理IC
- Unity3d静动态批处理Batching优化帧率、Batches(DrawCall) 初使用