現(xiàn)在的日常生活已經(jīng)離不開微信,本文將會拋磚引玉演示如何使用Python調(diào)用微信API做一些有意思的東西。
看完這一系列教程,你就能從頭開始實現(xiàn)自己關(guān)于微信的想法。
本文為教程的第二部分,主要以微信控制器、群發(fā)助手、好友刪除檢測為例演示如何調(diào)用微信API。
Python基礎(chǔ)并不困難,所以即使沒有這方面基礎(chǔ)輔助搜索引擎也完全可以學(xué)習(xí)本教程。
關(guān)于本教程有任何建議或者疑問,都歡迎郵件與我聯(lián)系(i7meavnktqegm1b@qq.com),或者在github上提出。
教程流程簡介
這一系列教程從如何分析微信協(xié)議開始,第一部分教你如何從零開始獲取并模擬擴展個人微信號所需要的協(xié)議。
第二部分將會就這些協(xié)議進行利用,以各項目為例介紹一些微信有意思功能的實現(xiàn)。
第三部分就協(xié)議的一些高級用法進行介紹,對框架做進一步介紹與擴展。
本文為教程的第二部分。
簡單成果展示
完成了本文的學(xué)習(xí),你將會完成三個小項目:(出于方便二次閱讀,括號中都放上了源碼鏈接)
使用微信協(xié)議完成機器人較為平常,如果對具體細節(jié)感興趣,可以添加個人號littlecodersh并回復(fù)“源代碼”。
本文主要基于微信API的第三方包itchat,你可以在項目主頁獲取更多信息。
本部分所需環(huán)境
本文是這一教程的第二部分,需要基本的pip可用的Python環(huán)境。
本教程使用的環(huán)境如下:
- Windows 8.1 (其他平臺也可用)
- Python 2 or 3
- 微信版本6.3.25
微信控制器

在項目主頁上,專門有人就微信作為智能家居入口向我提出了很多想法。
如果微信可以作為控制器,就可以不必自制手機端客戶端的麻煩。
其實這個需求實現(xiàn)起來非常簡單,這里我借鑒了yaphone的RasWxMusicbox,使用了其中部分的代碼作為演示。
這是一個通過微信控制電腦播放音樂的小項目,那么主要就是三個功能:
- 輸入“幫助”,顯示幫助
- 輸入“關(guān)閉”,關(guān)閉音樂播放
- 輸入具體歌名,進入歌曲的選擇
換成代碼就是這樣一個邏輯:
if msg == u'關(guān)閉':
close_music()
print(u'音樂已關(guān)閉')
if msg == u'幫助':
print(u'幫助信息')
else:
print(interact_select_song(msg))
那么現(xiàn)在需要解決的就是如何關(guān)閉音樂,如何選擇音樂和如何使用微信交互。
關(guān)閉音樂我們這里使用打開空文件的方式,而選擇音樂我們使用網(wǎng)易云音樂的API完成:
import os
# 通過該命令安裝該API: pip install NetEaseMusicApi
from NetEaseMusicApi import interact_select_song
with open('stop.mp3', 'w') as f: pass
def close_music():
os.startfile('stop.mp3')
而微信的調(diào)用可以通過itchat包簡單的完成,這里要注意的是:
- 有些賬號無法與自己通信,所以我們選擇與文件傳輸助手(filehelper)通信
- 為了防止對于其他消息的響應(yīng),我們在第一行過濾了無關(guān)信息
- itchat.run的選項分別為允許熱拔插,方便調(diào)試
# 接上段程序
# 通過該命令安裝該API: pip install itchat
import itchat
@itchat.msg_register(itchat.content.TEXT)
def music_player(msg):
if msg['ToUserName'] != 'filehelper': return
if msg['Text'] == u'關(guān)閉':
close_music()
itchat.send(u'音樂已關(guān)閉', 'filehelper')
if msg['Text'] == u'幫助':
itchat.send(u'幫助信息', 'filehelper')
else:
itchat.send(interact_select_song(msg['Text']), 'filehelper')
itchat.auto_login(True)
itchat.send(HELP_MSG, 'filehelper')
itchat.run()
itchat對常用功能都做好了封裝,調(diào)用還是非常容易的。
完整的程序我放在了gist上面,使用時不要忘記安裝第三方包。
通過與文件傳輸助手的交互,微信就能夠輕松變成其他程序的入口。
群發(fā)助手
在短信的時代,逢年過節(jié)都會需要接收和發(fā)送大量的短信。
雖然自己也看到短信就煩,但不發(fā)又怕會錯過什么。
所以當時就產(chǎn)生了各式各樣的群發(fā)工具,最簡單的比如在消息中加入昵稱,讓人感覺不像群發(fā)。
不過可惜的是,微信自帶的群發(fā)助手真的只是群發(fā)。
當然,稍加操作,一切皆有可能。
例如在消息中加入昵稱:
- 通過
get_friends方法可以輕松獲取所有的好友(好友首位是自己) - 基于不同的好友可以發(fā)送不同的消息
- 這條程序運行后是真的會發(fā)消息出去,如果只是演示目的,把
itchat.send改為print即可
#coding=utf8
import itchat, time
itchat.auto_login(True)
SINCERE_WISH = u'祝%s新年快樂!'
friendList = itchat.get_friends(update=True)[1:]
for friend in friendList:
# 如果是演示目的,把下面的方法改為print即可
itchat.send(SINCERE_WISH % (friend['DisplayName']
or friend['NickName']), friend['UserName'])
time.sleep(.5)
又例如給特定的人發(fā)送特定的消息。
我們這里通過群聊實現(xiàn),劃定一個群聊,在群聊內(nèi)則私信發(fā)送祝福。
- 如果僅是創(chuàng)建群聊不說話,對方是不會有提示的
- 群聊如果不保存到通訊錄,是無法在各設(shè)備之間同步的(所以itchat也無法讀取到)
- 群聊在被獲取的時候不會自帶用戶列表,所以需要使用
update_chatroom更新用戶列表 - 當然,如果只是演示目的,把
itchat.send改為print即可
#coding=utf8
import itchat, time
itchat.auto_login(True)
REAL_SINCERE_WISH = u'祝%s新年快樂!!'
chatroomName='wishgroup'
itchat.get_chatrooms(update=True)
chatrooms = itchat.search_chatrooms(name=chatroomName)
if chatrooms is None:
print(u'沒有找到群聊:' + chatroomName)
else:
chatroom = itchat.update_chatroom(chatrooms[0]['UserName'])
for friend in chatroom['MemberList']:
friend = itchat.search_friends(userName=friend['UserName'])
# 如果是演示目的,把下面的方法改為print即可
itchat.send(REAL_SINCERE_WISH % (friend['DisplayName']
or friend['NickName']), friend['UserName'])
time.sleep(.5)
所以我的通訊錄里會有從來不用的客戶群、教師群什么的。
完整的程序我放在了gist上面,使用時不要忘記安裝第三方包。
當然,為了防止誤操作,完整程序中我把所有的itchat.send換成了print。
另外,不只有文字可以發(fā)送,文件、圖片也都是可行的,具體操作見itchat的文檔了。
itchat獲取微信可以獲取到的各種內(nèi)容也都非常方便。
其余的例如生日,節(jié)日什么的就看具體需求了。
好友刪除檢測
有時候我們會想知道某個好友有沒有刪除自己或者把自己拉入黑名單。
這一操作使用itchat也會變的非常簡單。
原理的話,在于將好友拉入群聊時,非好友和黑名單好友不會被拉入群聊。
所以群聊的返回值中就有了好友與你關(guān)系的數(shù)據(jù)。
另外,群聊在第一次產(chǎn)生普通消息時才會被除創(chuàng)建者以外的人發(fā)現(xiàn)的(系統(tǒng)消息不算普通消息)。
這樣,就可以隱蔽的完成好友檢測。
寫成代碼的話,這個操作就是這樣的:(只是演示,不能運行,運行版本在段末)
chatroomUserName = '@1234567'
friend = itchat.get_friends()[1]
r = itchat.add_member_into_chatroom(chatroomUserName, [friend])
if r['BaseResponse']['ErrMsg'] == '':
status = r['MemberList'][0]['MemberStatus']
itchat.delete_member_from_chatroom(chatroom['UserName'], [friend])
return { 3: u'該好友已經(jīng)將你加入黑名單。',
4: u'該好友已經(jīng)將你刪除。', }.get(status,
u'該好友仍舊與你是好友關(guān)系。')
其中,通過add_member_into_chatroom操作獲取我們需要的返回值,即可得到好友的狀態(tài)。
同樣的,這次我們也將文件傳輸助手作為終端,具體方法與控制器一節(jié)類似。
這次我們確定的交互方式是接收“名片”消息,并判斷名片中的好友與自己的關(guān)系。
那么獲取名片信息的內(nèi)容可以這么寫:
import itchat
@itchat.msg_register(itchat.content.CARD)
def get_friend(msg):
if msg['ToUserName'] != 'filehelper': return
friendStatus = get_friend_status(msg['RecommendInfo'])
itchat.send(friendStatus['NickName'], 'filehelper')
itchat.auto_login(True)
itchat.run()
那么我們所需要的所有部分就都解決了,下面將他們組合起來即可。
完整的程序我放在了gist上面,使用時不要忘記安裝第三方包。
在網(wǎng)頁版微信的接口受到限制之前完全可以批量進行這一操作,檢測哪些好友刪除了自己。
但目前顯然操作存在頻率限制,所以只能做一些變通了。
之后的內(nèi)容
到這里這一篇文章的主要內(nèi)容就結(jié)束了。
主要從微信作為終端使用、自定義的消息交互、微信協(xié)議研究三方面開了一個簡單的頭。
其余有一些過于大眾,如機器人,就不再贅述。
而另一些,需要一定的基礎(chǔ)或者不適合分享,就留給各位自行研究。
如果要留個懸念,可以想象添加好友的方法status傳2,輕松實現(xiàn)好友病毒式擴張。
利用微信的API可以做很多事情,文檔我放在這里,祝好運!
結(jié)束語
希望讀完這篇文章能對你有幫助,有什么不足之處萬望指正(鞠躬)。
有什么想法或者想要關(guān)注我的更新,歡迎來Github上Star或者Fork。
160928
LittleCoder
EOF