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

相關文章
相關標籤/搜索