Python的WeRoBot框架开发公众号

简介: Python的WeRoBot框架开发公众号

最终的效果图:



20200303003159733.jpg



完整代码:


#coding:utf-8
# Filename:return_message5.py
# 被关注回复'Hello World!'
# 收到 笑话 回复糗百笑话,收到收到 电影 回复电影天堂最新电影,
# 收到 blog 回复我的简书博客,收到 音乐 回复一首音乐
# 收到 fight 回复一句话
from werobot import WeRoBot
import random
from werobot.replies import ArticlesReply, Article
robot = WeRoBot(token='your_token')
# 明文模式不需要下面三项
#robot.config["APP_ID"]=''
#robot.config["APP_SECRET"]=''
#robot.config['ENCODING_AES_KEY'] = ''
# 被关注
@robot.subscribe
def subscribe(message):
    return '''Hello World!
And nice to meet you.
:)
'''
# 读取文档里的笑话,把前三行存在 data2 里,字符串太长公众号会报错
def joke_data():
    filename = 'qiushibaike.txt'
    f = open(filename, 'r')
    data = f.read()
    f.close()
    data1 = data.split()
    data2 = ''
    for data_i in data1[0:3]:
        data2 += data_i + '\n' + '\n'
    return data2
# 读取文档里的电影名称
def movie_name():
    filename = 'movies_name.txt'
    f = open(filename, 'r')
    data = f.read()
    f.close()
    return data
# 从三首音乐里随机选一首
def music_data():
    music_list = [
            ['童话镇','陈一发儿','https://e.coka.la/wlae62.mp3','https://e.coka.la/wlae62.mp3'],
            ['都选C','缝纫机乐队','https://files.catbox.moe/duefwe.mp3','https://files.catbox.moe/duefwe.mp3'],
            ['精彩才刚刚开始','易烊千玺','https://e.coka.la/PdqQMY.mp3','https://e.coka.la/PdqQMY.mp3']
            ]
    num = random.randint(0,2)
    return music_list[num]
# 读取 fight.txt 里的句子,随机返回一句
def get_fighttxt():
    filename = 'fight.txt'
    f = open(filename, 'r')
    data = f.read()
    f.close()
    data1 = data.split()
    max_num = len(data1) - 1
    num = random.randint(0, max_num)
    data2 = data1[num]
    return data2
# 匹配 笑话 回复糗百笑话
@robot.filter('笑话')
def joke(message):
    data = joke_data()
    return data
#如果用
#@robot.text
#def joke(message):
#    if message.content == "笑话":
#会报错
#UnicodeWarning: Unicode equal comparison failed to convert both arguments to Unicode - interpreting them as being unequal
# 匹配 电影 回复电影名称
@robot.filter('电影')
def movie(message):
    name = movie_name()
    return name
# blog 回复个人博客
@robot.filter('blog')
def blog(message):
    reply = ArticlesReply(message=message)
    article = Article(
        title="Lansonli",
        description="Lansonli个人博客",
        img="https://avatar.csdnimg.cn/0/0/A/3_xiaoweite1_1568355559.jpg",
        url="https://lansonli.blog.csdn.net"
    )
    reply.add_article(article)
    return reply
# 匹配 音乐 回复一首歌
@robot.filter('音乐')
def music(message):
    music1 = music_data()
    return music1
# 匹配 fight 回复一句话
@robot.filter('fight')
def fight(message):
    data = get_fighttxt()
    return data
# 文本消息返回原文
@robot.text
def echo(message):
    return message.content
# 其他消息返回
@robot.handler
def hello(message):
    return '(O_o)??'
robot.config['HOST'] = '0.0.0.0'
robot.config['PORT'] = 80
robot.run()


分步讲解:



公众号分为企业号、服务号和订阅号,我们这里用订阅号,适用于个人


注册订阅号和购买服务器的过程不再赘述



1.验证服务器


在公众号后台配置服务器


image.png


填入自己的服务器地址(URL)和Token:


服务器地址可以是IP,也可以是域名,但必须以http://或https://开头,分别支持80端口和443端口。


Token随便填,一会代码里用得到。


选择明文模式,先不提交。


服务器上部署代码


先安装werobot


pip install WeRoBot


创建 hello_world.py,代码如下:


#coding:utf-8
# Filename:hello_world.py
# 验证服务器,并且收到的所有消息都回复'Hello World!'
import werobot
robot = werobot.WeRoBot(token='your token')
# @robot.handler 处理所有消息
@robot.handler
def hello(message):
    return 'Hello World!'
# 让服务器监听在 0.0.0.0:80
robot.config['HOST'] = '0.0.0.0'
robot.config['PORT'] = 80
robot.run()


'your token' 处填你的Token,然后运行



python hello_world.py


返回公众号的基本配置页面,点击提交,如果没有报错就验证成功了,最后点击“启用配置”



2.处理文本消息


# @robot.text 只处理文本消息
@robot.text
def echo(message):
    return '111'


3.匹配文本的两种方式


# 第一种方式
@robot.text
def joke(message):
    if message.content == "joke":
# 如果把"joke"换成"笑话"就会报错,这种方式不能匹配中文
# 第二种方式
@robot.filter('笑话')
def joke(message):
# 用 @robot.filter() 可以匹配中文


4.读取本地文档


# 以只读的方式,读取同目录文档 movies_name.txt 的内容
filename = 'movies_name.txt'
f = open(filename, 'r')
data = f.read()
f.close()
return data


5.回复图文消息


# blog 回复个人博客
from werobot.replies import ArticlesReply, Article
@robot.filter('blog')
def blog(message):
    reply = ArticlesReply(message=message)
    article = Article(
        title="v1coder",  #标题
        description="我的个人博客",  #简介
        img="https://*****.png",  #图片链接
        url="https://www.jianshu.com/u/7cb04d09491e"  #点击图片后跳转链接
    )
    reply.add_article(article)
    return reply

6.回复音乐


# 匹配 音乐 回复一首歌
@robot.filter('音乐')
def music(message):
    # 返回一个长度为四的列表
    return [
        '都选C',
        '缝纫机乐队',
        'https://files.catbox.moe/duefwe.mp3',
        'https://files.catbox.moe/duefwe.mp3'
    ]


分布讲解完毕。


最后:



结束当前代码运行:Ctrl + C


使程序在Linux下后台运行 (关掉终端继续让程序运行)的方法:



输入命令:


nohup 你的shell命令 &

回车,使终端回到shell命令行

停止程序在 Linux 后台运行的方法:


ps x  # 显示所有进程
kill 进程号  # 结束进程


公众号测试账号,拥有所有权限


全局返回码说明,可以根据返回码信息调试接口,排查错误。


目录
相关文章
|
11天前
|
存储 数据库连接 API
Python环境变量在开发和运行Python应用程序时起着重要的作用
Python环境变量在开发和运行Python应用程序时起着重要的作用
55 15
|
23天前
|
数据采集 存储 JSON
Python网络爬虫:Scrapy框架的实战应用与技巧分享
【10月更文挑战第27天】本文介绍了Python网络爬虫Scrapy框架的实战应用与技巧。首先讲解了如何创建Scrapy项目、定义爬虫、处理JSON响应、设置User-Agent和代理,以及存储爬取的数据。通过具体示例,帮助读者掌握Scrapy的核心功能和使用方法,提升数据采集效率。
70 6
|
23天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
125 45
|
17天前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
63 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
18天前
|
JSON 安全 API
如何使用Python开发API接口?
在现代软件开发中,API(应用程序编程接口)用于不同软件组件之间的通信和数据交换,实现系统互操作性。Python因其简单易用和强大功能,成为开发API的热门选择。本文详细介绍了Python开发API的基础知识、优势、实现方式(如Flask和Django框架)、实战示例及注意事项,帮助读者掌握高效、安全的API开发技巧。
42 3
如何使用Python开发API接口?
|
6天前
|
缓存 API 数据库
Python哪个框架合适开发速卖通商品详情api?
在跨境电商平台速卖通的商品详情数据获取与整合中,Python 语言及其多种框架(如 Flask、Django、Tornado 和 FastAPI)提供了高效解决方案。Flask 简洁灵活,适合快速开发;Django 功能全面,适用于大型项目;Tornado 性能卓越,擅长处理高并发;FastAPI 结合类型提示和异步编程,开发体验优秀。选择合适的框架需综合考虑项目规模、性能要求和团队技术栈。
18 2
|
11天前
|
JSON API 数据格式
如何使用Python开发1688商品详情API接口?
本文介绍了如何使用Python开发1688商品详情API接口,获取商品的标题、价格、销量和评价等详细信息。主要内容包括注册1688开放平台账号、安装必要Python模块、了解API接口、生成签名、编写Python代码、解析返回数据以及错误处理和日志记录。通过这些步骤,开发者可以轻松地集成1688商品数据到自己的应用中。
26 1
|
17天前
|
数据采集 存储 JSON
Python爬虫开发中的分析与方案制定
Python爬虫开发中的分析与方案制定
|
22天前
|
算法 测试技术 开发者
性能优化与代码审查:提升Python开发效率
性能优化与代码审查:提升Python开发效率
31 1
|
8天前
|
安全 API 数据库
Python哪个框架合适开发淘宝商品详情api?
在数字化商业时代,开发淘宝商品详情API成为企业拓展业务的重要手段。Python凭借其强大的框架支持,如Flask、Django、Tornado和FastAPI,为API开发提供了多样化的选择。本文探讨了这些框架的特点、优势及应用场景,帮助开发者根据项目需求选择最合适的工具,确保API的高效、稳定与可扩展性。
19 0
下一篇
无影云桌面