Python使用微信接入图灵机器人

1.wxpy库介绍

  • wxpy 在 itchat 的基础上,经过大量接口优化提高了模块的易用性,并进行丰富的功能扩展。 文档地址:https://wxpy.readthedocs.iohtml

  • 从 PYPI 官方源下载安装:python

pip install -U wxpy
  • 从豆瓣 PYPI 镜像源下载安装,推荐国内用户选用:
pip install -U wxpy -i "https://pypi.doubanio.com/simple/"

2.图灵机器人

  • 首先注册一个帐号:http://www.turingapi.com/ ,而后能够建立一个本身的图灵机器人;json

  • 要使用图灵机器人能够先看一下帮助中心,里面有接入教程,好比说图灵机器人的接口地址、请求方式、请求参数等,这些在接入图灵机器人的时候会用到;api

3.使用微信接入图灵机器人

  • 使用微信接入图灵机器人须要用到wxpy库,先导入这个库,而后建立一个接口函数;缓存

  • 而后在这个函数中配置请求参数(json格式),好比: reqType:输入类型,0表示文本(默认)、1表示图片、2表示音频;微信

  • perception:输入信息,inputText(text)表示文本信息、inputImage(url)表示图片信息、inputMedia(url)表示音频信息、selfInfo(location)表示客户端属性;异步

  • userInfo:用户参数,apiKey机器人标识(进入建立的机器人就能看到)、userId用户ID(在用户头像旁边)、groupId群聊ID、userIdName群内用户昵称;async

  • 接口地址:http://openapi.tuling123.com/openapi/api/v2 ,在文档帮助中心的接入教程中有;函数

  • 经过requests.post()方法传递请求地址和配置请求参数,配置请求参数能够经过json.dumps()方法转化为json格式,而后会返回一个response响应对象;post

  • 而后将返回的response响应对象使用json.loads()方法加载到内存转换为字典,而后将之做为函数的返回值;

  • 接着就能够经过python操做微信,须要先初始化机器人,如bot = Bot(),而后根据需求针对好友或者群聊回复消息;

from wxpy import *
import requests
import json
def tuling_robot(text):
    url = "http://openapi.tuling123.com/openapi/api/v2"
    # 本身的key
    apiKey=""
    # 本身的id
    userID = ""
    payload={
        "reqType": 0,
        "perception": {
            "inputText": {
                "text": text
            }
        },
        "userInfo": {
            "apiKey": apiKey,
            "userId": userID
        }
    }
    r = requests.post(url,data=json.dumps(payload))
    ret = json.loads(r.text)
    return ret['results'][0]['values']['text']
bot = Bot(console_qr=2, cache_path="botoo.pkl")
# 也能够针对某个群发送消息
@bot.register()
def send_all(msg):
    print('收到数据' + str(msg))
    if (msg.type != 'Text'):
        ret = '这个我回答不了你'
    else:
        ret = tuling_robot(msg.text)
    print('发送数据' + str(ret))
    return ret
embed()

4.wxpy.Bot()

  • 语法:wxpy.Bot(cache_path=None, console_qr=False, qr_path=None, qr_callback=None, login_callback=None, logout_callback=None)

  • 机器人对象,用于登录和操做微信帐号,涵盖大部分 Web 微信的功能;

  • cache_path:设置当前会话的缓存路径,并开启缓存功能(默认不开启),开启缓存后可在短期内避免重复扫码,缓存失效时会从新要求登录,设为 True 时,使用默认的缓存路径 ‘wxpy.pkl’;

  • console_qr:在终端中显示登录二维码,须要安装 pillow 模块;

  • qr_path:保存二维码的路径;

  • qr_callback :得到二维码后的回调,能够用来定义二维码的处理方式,接收参数: uuid, status, qrcode;

  • login_callback:登录成功后的回调,若不指定,将进行清屏操做,并删除二维码文件;

  • logout_callback:登出时的回调;

5.Bot.register()

  • 语法:Bot.register(chats=None, msg_types=None, except_self=True, run_async=True, enabled=True)

  • 能够做为函数的装饰器,用于注册消息配置,参数chats表示消息所在的聊天对象,单个或列表形式的多个聊天对象或聊天类型,为空时匹配全部聊天对象、msg_types 表示 消息的类型,单个或列表形式的多个消息类型,为空时匹配全部消息类型(SYSTEM 类消息除外) 、except_self表示排除由本身发送的消息、run_async 表示是否异步执行所配置的函数,可提升响应速度、enabled 表示当前配置的默认开启状态,可过后动态开启或关闭;

参考:https://www.9xkd.com/user/plan-view.html?id=1072150704

相关文章
相关标签/搜索