91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解Python-Wechaty: 面向IM軟件的聊天機器人框架

發布時間:2021-10-21 16:32:56 來源:億速云 閱讀:135 作者:iii 欄目:編程語言

這篇文章主要講解了“如何理解Python-Wechaty: 面向IM軟件的聊天機器人框架”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何理解Python-Wechaty: 面向IM軟件的聊天機器人框架”吧!

Python-wechaty能夠使用少量代碼即可完成一個機器人,使用起來非常簡單,基于OOP的設計思路能夠很好監聽和處理微信內部大量的事件,比如:自動回復消息,定時發送消息,拉人入群,好友申請同意等等。此外,目前的插件系統里面有很多拿來即用的工具,比如拉人入群等。當然開發一個自己的插件也是非常簡單,無需很高深的概念,只需要你能夠理解事件和OOP即可。

python-wechaty項目源于wechaty,甚至說很大程度上代碼是直接從其翻譯過來的,然后加上一些python的特性,讓其更加pythonic。作為一個IM的入口工具,未來我們也將添加更多的Chatbot元素進去,讓其能夠成為一個真正的聊天機器人。

在介紹python-wechaty之前,還是簡要介紹一下wechaty。

wechaty

或許有很多人會把wechaty和wechat聯系起來,畢竟在名稱上面只是一字之差。這個得從wechaty的起源開始說起,起初,此項目只是作為微信的一個工具庫,能夠進行一些簡單的自動化操作過程,比如:定時發送消息,入群消息發送,好友申請接受等。

可隨著項目的逐步更新,wechaty已支持主流的IM軟件,比如:微信,釘釘,Telegram。

這個項目從2016年開始,到現在已經獲取8k star,是一個非常穩定且用戶量非常龐大的項目。官方對其給出的介紹是:

  • A Conversational AI RPA SDK for Chatbot

所以wechaty作為IM ChatBot的入口工具,是很多聊天機器人的基礎架構組件,也將會逐步支持主流聊天機器人的功能。

python-wchaty的誕生

與Wechaty的結緣是在2019年底的一次技術沙龍會上,認識到了原來6行代碼就能夠開發出一款足夠靈活的機器人,當時給我一個很大的震撼。微信作為我們日常聊天工具之一,如果能夠對其做一些自動化的過程,能夠很大程度上減少繁瑣過程的工作量,比如說:辦活動時的拉人入群,定時提醒用戶打卡,提醒女朋友姨媽快來了等等。而wechaty能夠很好的支持以上所有功能,只需要簡單的幾行代碼即可完成。回去之后就立馬著手相關資料的查閱,然后逐步進入wechaty的社區。

一個很巧的機會群里面說可以開發一款go-wechaty的開發,當時我就在想,為什么不能夠有一款python-wechaty呢,然后就毛遂自薦,成為了python-wechaty的聯合作者之一。由于對開源軟件和DevOps不是很熟悉,起步階段遇到了很多的問題,不過經過社區大佬的耐心指導,目前已能夠完成對issue和feature的開發和管理。親身經歷,建議大家有機會一定要參加開源項目,能夠讓你學習到很多知識點。

最簡單的Bot

使用python-wechaty能夠很簡單的開發一款Bot,特別是使用了一個插件系統之后,如下所示:

如何理解Python-Wechaty: 面向IM軟件的聊天機器人框架

以上代碼中實現了兩個主要的功能:

  • 當Bot接受到一個#ding信號,就立馬回復一個dong消息,這就是一個基本的ding-dong-bot。

  • 當接受到查閱天氣的文本語句時,則返回對應的天氣查詢結果,比如:今天天氣如何?

以上兩個插件是系統內置的,后續也會增加更多的拿來即用的實用插件,當然用戶也可創建自己的插件,方式很簡單。

如何開發插件系統

在了解如何開發插件系統之前,可先移駕Plug-in`,插件系統支持對插件的安裝,卸載,自定義配置等內容  ,至于具體的實現形式我相信也是需要面對具體的應用場景。而在Wechaty這個面相事件型且交互邏輯非常簡單的場景下,插件的設計與開發就非常簡單。

我們現在直接來看看,系統內置的叮咚插件是如何實現的。

"""basic ding-dong bot for the wechaty plugin""" from typing import Union  from wechaty import Message, Contact, Room, FileBox from wechaty.plugin import WechatyPlugin   class DingDongPlugin(WechatyPlugin):     """basic ding-dong plugin"""     @property     def name(self):         """name of the plugin"""         return 'ding-dong'      async def on_message(self, msg: Message):         """listen message event"""         from_contact = msg.talker()         text = msg.text()         room = msg.room()         if text == '#ding':             conversation: Union[                 Room, Contact] = from_contact if room is None else room             await conversation.ready()             await conversation.say('dong')

代碼很簡單,不過也是需要氛圍一下幾個層面來介紹。

  • WechatyPlugin

  • on_[event_name]

  • init_plugin

WechatyPlugin

此類為一個抽象類,所有的插件必須要繼承此基類,并重寫其中的函數。

  • name 屬性函數為抽象函數,必須重寫。主要是為了標識插件的名稱,作為插件唯一性身份認證。

  • init_plugin 初始化函數能夠支持插件的初始化過程,比如初始化定時器對象,數據庫延遲連接對象等。

  • on_[event_name]此類函數主要是為了監聽系統中的不同事件,比如:on_message, on_login,  on_friendship等事件的監聽都只需要重寫一下函數即可完成。不同插件之間以及不同事件之間都是獨立的,能夠很好的專注于不同業務場景下的開發。

event_name

python-wechaty很大程度上是由事件驅動,畢竟很多操作都是基于消息接受觸發,由此事件的監聽是其基礎特性,可能第一感覺就是實用EventEmitter這種模式來監聽事件,這樣每個事件我都可以注冊不同的函數來監聽,每個函數中會有不同的邏輯處理。這也是傳統的事件監聽方法,可這至少會給開發上帶來一些不方便:函數的參數需要查閱文檔才能夠獲知,標準的函數式編程。

  • 我不是說函數式編程不好,只是在這種場景下對系統性能并不能提升多少,且python-wechaty 也并不能太注重性能。

由此將其擴展了OOP的方式,用戶可繼承Wechaty或WechatyPlugin來監聽不同的事件,且在常規的代碼編輯器里面重寫函數時就可以自動填充函數參數,從而減少查閱事件函數參數的問題。

監聽事件的類型有:error, friendship, heartbeat, login, logout, message, ready,  room_invite, room_join, room_leave, room_topic, scan。

在上面已經展示了WechatyPlugin如何開發,需要注意的地方,那接下來我將給大家詳細介紹一下最基礎的每日一說的機器人如何開發。

每日一說機器人

每日一說,顧名思義每天每個固定時間段發送一個祝福或提醒,具體內容可自定義。這其中需要注意幾點:

  • 機器人內部有一個調度器,用于調度時間事件的觸發。

  • 機器人可給制定的人和群發送對應的內容。

以上的功能我封裝成一個插件,然后注入到python-wechaty中即可。

"""daily word plugin""" from datetime import datetime  from apscheduler.schedulers.asyncio import AsyncIOScheduler  from wechaty import Wechaty from wechaty.plugin import WechatyPlugin   class DailyPlugin(WechatyPlugin):     """     say something everyday, like `Daily Words`     """     @property     def name(self) -> str:         """get the name of the plugin"""         return 'dayily'      async def tick(self):         """time tick for the plugin scheduler"""         room_id = get_room_id()         room = self.bot.Room.load(room_id)         await room.ready()         await room.say(f'i love you -> {datetime.now()}')      async def init_plugin(self, wechaty: Wechaty):         """init plugin"""         await super().init_plugin(wechaty)         scheduler = AsyncIOScheduler()         scheduler.add_job(self.tick, 'cron', hour=6, minute=16)         scheduler.start()

插件就開發完了,然后將其注入到Wechaty中即可跑起來。

async def main():     bot = Wechaty().use(DailyPlugin())     await bot.start() asyncio.run(main())

是不是超級簡單,插件系統幫你隔離所有的業務場景,讓代碼非常易于開發和維護。

python-wechaty還可以做更多

現在python-wechaty只完成了基本的Chatbot入口工具,離真正的聊天機器人還距離很遠,所以未來還有很多工作量可以做。

感謝各位的閱讀,以上就是“如何理解Python-Wechaty: 面向IM軟件的聊天機器人框架”的內容了,經過本文的學習后,相信大家對如何理解Python-Wechaty: 面向IM軟件的聊天機器人框架這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

仲巴县| 嵊州市| 扶沟县| 定襄县| 车险| 陈巴尔虎旗| 东明县| 舒城县| 苏尼特左旗| 台南市| 雅江县| 乌鲁木齐县| 紫金县| 伊通| 化德县| 韶山市| 凤庆县| 邢台县| 霸州市| 珲春市| 安龙县| 萨迦县| 县级市| 武鸣县| 甘孜县| 云浮市| 浪卡子县| 富顺县| 茂名市| 长泰县| 长兴县| 昌图县| 壤塘县| 阿拉善左旗| 宁陕县| 都匀市| 保德县| 廉江市| 青龙| 通城县| 略阳县|