wxpy 微信聊天机器人的实现

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/hellokandy/article/details/90665129

一、安装wxpy包

从 PYPI 官方源下载安装 (在国内可能比较慢或不稳定):

pip install -U wxpy

从豆瓣 PYPI 镜像源下载安装,通过cmd中输入命令进行安装 (推荐国内用户选用):

pip install -U wxpy -i "https://pypi.doubanio.com/simple/"

 

二、在python中登录微信web版

from wxpy import *
#初始化执行登陆操作,需要手机扫描登陆
bot = Bot()

 有些情况可能不能通过终端打开图片(如部署在服务器上时),我们可以通过参数选择在终端内显示二维码,这样代码会变为:

from wxpy import *
bot = Bot(console_qr=True)

如果你发现这样设置终端中的二维码变形了,可以尝试传入console_qr=1(或其他倍数)来进行调整字幅宽度。如果需要反色显示,可以使用负数来进行反色操作。

如果你认为每次都需要扫描二维码很麻烦,可以启用缓存,来保存自己的登录状态:

bot = Bot(console_qr=True, cache_path=True)

 

三、部分简单功能

首先我们尝试给自己和文件传输助手发消息:

# 给机器人自己发送消息
bot.self.send('Hello World!')
# 给文件传输助手发送消息
bot.file_helper.send('Hello World!')

如果无法给机器人自身发送消息,请参考 机器人对象 - wxpy 0.3.9.7 文档

# 查找昵称为'风移影动'的好友
my_friend = bot.friends().search(u'风移影动')[0]
# <Friend: 风移影动>

wxpy同时也包括了发送不同类型消息的方法,通过这些方法可以发送各种不同类型的消息。以下是样例使用方式:

# 发送文本
my_friend.send('Hello, WeChat!')
# 发送图片
my_friend.send_image('my_picture.png')
# 发送视频
my_friend.send_video('my_video.mov')
# 发送文件
my_friend.send_file('my_file.zip')
# 以动态的方式发送图片
my_friend.send('@img@my_picture.png')

 

四、自动处理消息

wxpy提供了注册消息的方法,可以简单将各种类型的消息注册并自定义处理方式。

注册消息使用简单的@bot.register()方法:

# 获取所有类型的消息(好友消息、群聊、公众号,不包括任何自己发送的消息)
# 并将获得的消息打印到控制台
@bot.register()
def print_others(msg):
    print(msg)

 wxpy也可以给注册消息的类型加上限制:

# 回复 my_friend 发送的消息
@bot.register(my_friend)
def reply_my_friend(msg):
    return 'received: {} ({})'.format(msg.text, msg.type)
 
# 回复发送给自己的消息,可以使用这个方法来进行测试机器人而不影响到他人
@bot.register(bot.self, except_self=False)
def reply_self(msg):
    return 'received: {} ({})'.format(msg.text, msg.type)
 
# 打印出所有群聊中@自己的文本消息,并自动回复相同内容
# 这条注册消息是我们构建群聊机器人的基础
@bot.register(Group, TEXT)
def print_group_msg(msg):
    if msg.is_at:
        print(msg)
        msg.reply(meg.text)

当然仅仅写以上内容,会导致你的程序主程序运行结束自然退出。wxpy给出了embed()方法,在程序末尾(或其他你想要暂停调试的地方)加上embed()方法就可以让程序保持运行,同时进入Python命令行。

# 进入 Python 命令行、让程序保持运行
# 推荐使用
embed()
 
# 或者仅仅堵塞线程
# bot.join()

关于消息注册的文档,更多内容可以参考 消息处理 - wxpy 文档

 

五、智能机器人回复

需要在http://www.tuling123.com上注册账号,通过图灵机器人完成初级的智能回复,比如询问天气等等

from wxpy import *
import requests
import json

bot = Bot(cache_path=True)

def auto_replay(text):
    url = "http://www.tuling123.com/openapi/api"
    api_key = "7*****************b"
    payload = {'key':api_key,
               'info':text,
               'userid':'rebot'}
    r = requests.post(url, data=json.dumps(payload))
    result = json.loads(r.content)
    return result['text']
#注意!这是所有人都回复
@bot.register()
def print_message(msg):
    #print(msg.text)
    return auto_replay(msg.text)

 

六、指定群聊/人自动回复

#指定群聊
group = bot.groups().search('群聊名')[0]

#指定好友
friend = bot.friends().search('好友名')[0]

#按需求修改参数
@bot.register(group,msg_types=TEXT)

 

七、可能会遇到的一些问题

报错[SSL: CERTIFICATE_VERIFY_FAILED]

可能的解决方案一:

pip install -U requests[security]

可能的解决方案二:

进入python后运行:

import certifi 
print(certifi.old_where())
# /usr/local/lib/python2.7/site-packages/certifi/weak.pem

把打印出的路径放入环境变量REQUESTS_CA_BUNDLE中。具体而言是在*nix环境下运行:

export REQUESTS_CA_BUNDLE='What you get'

或是在Windows中使用系统面板进行修改。

展开阅读全文

没有更多推荐了,返回首页