转载于:https://segmentfault.com/a/1190000009420701#articleHeader37python
sudo pip install itchat
android
itchat.auto_login()
这种方法将会经过微信扫描二维码登陆,可是这种登陆的方式确实短期的登陆,并不会保留登陆的状态,也就是下次登陆时仍是须要扫描二维码,若是加上hotReload==True
,那么就会保留登陆的状态,至少在后面的几回登陆过程当中不会再次扫描二维码,该参数生成一个静态文件itchat.pkl
用于存储登陆状态web
这里主要使用的是灰调函数的方法,登陆完成后的方法须要赋值在
loginCallback
中退出后的方法,须要赋值在exitCallback
中.若不设置loginCallback
的值, 将会自动删除二维码图片并清空命令行显示.正则表达式
import itchat, time def lc(): print("Finash Login!") def ec(): print("exit") itchat.auto_login(loginCallback=lc, exitCallback=ec) time.sleep() itchat.logout() #强制退出登陆
send(msg="Text Message", toUserName=None)
segmentfault参数:微信
msg
: 文本消息内容app
@fil@path_to_file
: 发送文件ide
@img@path_to_img
: 发送图片函数
@vid@path_to_video
: 发送视频测试
toUserName
: 发送对象, 若是留空, 将发送给本身.返回值
True
orFalse
实例代码
# coding-utf-8 import itchat itchat.auto_login() itchat.send("Hello World!") ithcat.send("@fil@%s" % '/tmp/test.text') ithcat.send("@img@%s" % '/tmp/test.png') ithcat.send("@vid@%s" % '/tmp/test.mkv')
send_msg(msg='Text Message', toUserName=None)
,其中的的msg
是要发送的文本,toUserName
是发送对象, 若是留空, 将发送给本身,返回值为True
或者False
实例代码
import itchat itchat.auto_login() itchat.send_msg("hello world.")
send_file(fileDir, toUserName=None)
fileDir
是文件路径, 当文件不存在时, 将打印无此文件的提醒,返回值为True
或者False
实例代码
mport itchat
itchat.auto_login()
itchat.send_file("/tmp/test.txt")
send_image(fileDir, toUserName=None)
参数同上实例代码
import itchat itchat.auto_login() itchat.send_img("/tmp/test.txt")
send_video(fileDir, toUserName=None)
参数同上实例代码
import itchat itchat.auto_login() itchat.send_video("/tmp/test.txt")
itchat
将根据接受到的消息类型寻找对应的已注册的方法.
若是一个消息类型没有对应的注册方法, 该消息将会被舍弃.
在运行过程当中也能够动态注册方法, 注册方式与结果不变.
不带具体对象注册, 将注册为普通消息的回复方法.
import itchat from itchat.content import * @itchat.msg_register(TEXT) #这里的TEXT表示若是有人发送文本消息,那么就会调用下面的方法 def simple_reply(msg): #这个是向发送者发送消息 itchat.send_msg('已经收到了文本消息,消息内容为%s'%msg['Text'],toUserName=msg['FromUserName']) return "T reveived: %s" % msg["Text"] #返回的给对方的消息,msg["Text"]表示消息的内容
带对象参数注册, 对应消息对象将调用该方法,其中
isFriendChat
表示好友之间,isGroupChat
表示群聊,isMapChat
表示公众号
import itchat from itchat.content import * @itchat.msg_register(TEXT, isFriendChat=True, isGroupChat=True,isMpChat=True) def text_reply(msg): msg.user.send("%s : %s" % (mst.type, msg.text))
消息类型
向注册方法传入的msg
包含微信返回的字典的全部内容.itchat
增长Text
,Type
(也就是参数) 键值, 方便操做.
itcaht.content
中包含全部的消息类型参数, 以下表
参数 | l类型 | Text 键值 |
---|---|---|
TEXT | 文本 | 文本内容(文字消息) |
MAP | 地图 | 位置文本(位置分享) |
CARD | 名片 | 推荐人字典(推荐人的名片) |
SHARING | 分享 | 分享名称(分享的音乐或者文章等) |
PICTURE 下载方法 | 图片/表情 | |
RECORDING | 语音 | 下载方法 |
ATTACHMENT | 附件 | 下载方法 |
VIDEO | 小视频 | 下载方法 |
FRIENDS | 好友邀请 | 添加好友所需参数 |
SYSTEM | 系统消息 | 更新内容的用户或群聊的UserName组成的列表 |
NOTE | 通知 | 通知文本(消息撤回等) |
itchat
的附件下载方法存储在msg
的Text
键中.
发送的文件名(图片给出的默认文件名), 都存储在msg
的FileName
键中.
下载方法, 接受一个可用的位置参数(包括文件名), 并将文件响应的存储.
注意:下载的文件存储在指定的文件中,直接将路径与FileName
链接便可,如msg["Text"]('/tmp/weichat'+msg['FileName'])
@itchat.msg_register([PICTURE, RECORDING, ATTACHMENT, VIDEO]) def download_files(msg): #msg.download(msg['FileName']) #这个一样是下载文件的方式 msg['Text'](msg['FileName']) #下载文件 #将下载的文件发送给发送者 itchat.send('@%s@%s' % ('img' if msg['Type'] == 'Picture' else 'fil', msg["FileName"]), msg["FromUserName"])
增长了三个键值,以下:
isAt
判断是否 @ 本号
ActualNickName
: 实际NickName
(昵称)
Content
: 实际Content
测试程序
import itcaht from itchat.content import TEXT @itchat.msg_register(TEXT, isGroupChat=True) def text_reply(msg): if(msg.isAt): #判断是否有人@本身 #若是有人@本身,就发一个消息告诉对方我已经收到了信息 itchat.send_msg("我已经收到了来自{0}的消息,实际内容为{1}".format(msg['ActualNickName'],msg['Text']),toUserName=msg['FromUserName']) itchat.auto_login() itchat.run()
总的来讲就是后面注册同种类型的消息会覆盖以前注册的消息,详情见文档https://itchat.readthedocs.io/zh/latest/
注意:全部的消息内容都是能够用键值对来访问的,如
msg["FromUserName]
就是查看发送者,itchat.search_friends(userName=msg['FromUserName'])['NickName']
查看的是当发送者昵称
通常的消息都遵循如下的内容:
{
"FromUserName": "", "ToUserName": "", "Content": "", "StatusNotifyUserName": "", "ImgWidth": 0, "PlayLength": 0, "RecommendInfo": {}, "StatusNotifyCode": 0, "NewMsgId": "", "Status": 0, "VoiceLength": 0, "ForwardFlag": 0, "AppMsgType": 0, "Ticket": "", "AppInfo": {}, "Url": "", "ImgStatus": 0, "MsgType": 0, "ImgHeight": 0, "MediaId": "", "MsgId": "", "FileName": "", "HasProductId": 0, "FileSize": "", "CreateTime": 0, "SubMsgType": 0 }
MsgType: 51 FromUserName: 本身ID ToUserName: 本身ID StatusNotifyUserName: 最近联系的联系人ID Content: <msg> <op id='4'> <username> # 最近联系的联系人 filehelper,xxx@chatroom,wxid_xxx,xxx,... </username> <unreadchatlist> <chat> <username> # 朋友圈 MomentsUnreadMsgStatus </username> <lastreadtime> 1454502365 </lastreadtime> </chat> </unreadchatlist> <unreadfunctionlist> # 未读的功能帐号消息,群发助手,漂流瓶等 </unreadfunctionlist> </op> </msg>
MsgType: 1 FromUserName: 发送方ID ToUserName: 接收方ID Content: 消息内容
itchat
增长了Text
键, 键值为 下载该图片的方法.
MsgType: 3 FromUserName: 发送方ID ToUserName: 接收方ID MsgId: 用于获取图片,用于表示每一条消息 Content: <msg> <img length="6503" hdlength="0" /> <commenturl></commenturl> </msg>
拓展:若是想要获得
Content
中的具体内容可使用正则表达式匹配出来
*
itchat
增长了Text
键, 键值为 下载该视频的方法.*
MsgType: 62 FromUserName: 发送方ID ToUserName: 接收方ID MsgId: 用于获取小视频 Content: <msg> <img length="6503" hdlength="0" /> <commenturl></commenturl> </msg>
itchat
增长了Text
键, 键值为 该地点的文本形式.
MsgType: 1 FromUserName: 发送方ID ToUserName: 接收方ID Content: http://weixin.qq.com/cgi-bin/redirectforward?args=xxx OriContent:<?xml version="1.0"?> <msg> <location x="34.195278" y="117.177803" scale="16" label="江苏省徐州市铜山区新区海河路" maptype="0" poiname="江苏师范大学大学生公寓园区" /> </msg>
itchat
增长了Text
键, 键值为 该调用add_friend
须要的属性.
MsgType: 42 FromUserName: 发送方ID ToUserName: 接收方ID Content: <?xml version="1.0"?> <msg bigheadimgurl="" smallheadimgurl="" username="" nickname="" shortpy="" alias="" imagestatus="3" scene="17" province="" city="" sign="" sex="1" certflag="0" certinfo="" brandIconUrl="" brandHomeUrl="" brandSubscriptConfigUrl="" brandFlags="0" regionCode="" /> RecommendInfo: { "UserName": "xxx", # ID,这里的是昵称 "Province": "xxx", "City": "xxx", "Scene": 17, "QQNum": 0, "Content": "", "Alias": "xxx", # 微信号 "OpCode": 0, "Signature": "", "Ticket": "", "Sex": 0, # 1:男, 2:女 "NickName": "xxx", # 昵称 "AttrStatus": 4293221, "VerifyFlag": 0 }
下面是添加好友的测试代码
@itchat.msg_register(itchat.content.CARD,isFriendChat=True) def simply(msg): print msg['Text'] print msg['Content'] itchat.add_friend(userName=msg['Text']['UserName']) #添加推荐的好友 print msg['RecommendInfo'] print msg['RecommendInfo']['UserName']
*
itchat
增长了Text
键,键值为下载该语音文件的方法,下载下来的是MP3
的格式
MsgType: 34 FromUserName: 发送方ID ToUserName: 接收方ID MsgId: 用于获取语音 Content: <msg> <voicemsg endflag="1" cancelflag="0" forwardflag="0" voiceformat="4" voicelength="1580" length="2026" bufid="216825389722501519" clientmsgid="49efec63a9774a65a932a4e5fcd4e923filehelper174_1454602489" fromusername="" /> </msg>
下载方法:
msg['Text'](msg['FileName'])
itchat
添加了Text
键,键值为下载该图片表情的方法。
注意:本人亲测对于一些微信商店提供的表情是不能下载成功的,这里的自带的表情emoji
是属于TEXT
类别的,所以若是将其注册为PICTURE
消息类型的话是不能够监测到的
MsgType: 47 FromUserName: 发送方ID ToUserName: 接收方ID Content: <msg> <emoji fromusername = "" tousername = "" type="2" idbuffer="media:0_0" md5="e68363487d8f0519c4e1047de403b2e7" len = "86235" productid="com.tencent.xin.emoticon.bilibili" androidmd5="e68363487d8f0519c4e1047de403b2e7" androidlen="86235" s60v3md5 = "e68363487d8f0519c4e1047de403b2e7" s60v3len="86235" s60v5md5 = "e68363487d8f0519c4e1047de403b2e7" s60v5len="86235" cdnurl = "http://emoji.qpic.cn/wx_emoji/eFygWtxcoMF8M0oCCsksMA0gplXAFQNpiaqsmOicbXl1OC4Tyx18SGsQ/" designerid = "" thumburl = "http://mmbiz.qpic.cn/mmemoticon/dx4Y70y9XctRJf6tKsy7FwWosxd4DAtItSfhKS0Czr56A70p8U5O8g/0" encrypturl = "http://emoji.qpic.cn/wx_emoji/UyYVK8GMlq5VnJ56a4GkKHAiaC266Y0me0KtW6JN2FAZcXiaFKccRevA/" aeskey= "a911cc2ec96ddb781b5ca85d24143642" ></emoji> <gameext type="0" content="0" ></gameext> </msg>
主要针对的是分享的文章等等
MsgType: 49 AppMsgType: 5 FromUserName: 发送方ID ToUserName: 接收方ID Url: 连接地址 FileName: 连接标题 Content: <msg> <appmsg appid="" sdkver="0"> <title></title> <des></des> <type>5</type> <content></content> <url></url> <thumburl></thumburl> ... </appmsg> <appinfo> <version></version> <appname></appname> </appinfo> </msg>
主要针对的是音乐
MsgType: 49 AppMsgType: 3 FromUserName: 发送方ID ToUserName: 接收方ID Url: 连接地址 FileName: 音乐名 AppInfo: # 分享连接的应用 { Type: 0, AppID: wx485a97c844086dc9 } Content: <msg> <appmsg appid="wx485a97c844086dc9" sdkver="0"> <title></title> <des></des> <action></action> <type>3</type> <showtype>0</showtype> <mediatagname></mediatagname> <messageext></messageext> <messageaction></messageaction> <content></content> <contentattr>0</contentattr> <url></url> <lowurl></lowurl> <dataurl> http://ws.stream.qqmusic.qq.com/C100003i9hMt1bgui0.m4a?vkey=6867EF99F3684&guid=ffffffffc104ea2964a111cf3ff3edaf&fromtag=46 </dataurl> <lowdataurl> http://ws.stream.qqmusic.qq.com/C100003i9hMt1bgui0.m4a?vkey=6867EF99F3684&guid=ffffffffc104ea2964a111cf3ff3edaf&fromtag=46 </lowdataurl> <appattach> <totallen>0</totallen> <attachid></attachid> <emoticonmd5></emoticonmd5> <fileext></fileext> </appattach> <extinfo></extinfo> <sourceusername></sourceusername> <sourcedisplayname></sourcedisplayname> <commenturl></commenturl> <thumburl> http://imgcache.qq.com/music/photo/album/63/180_albumpic_143163_0.jpg </thumburl> <md5></md5> </appmsg> <fromusername></fromusername> <scene>0</scene> <appinfo> <version>29</version> <appname>摇一摇搜歌</appname> </appinfo> <commenturl></commenturl> </msg>
itchat
增长了三个群聊相关的键值:
isAt
: 判断是否 @ 本号
ActualNickName
: 实际NickName
Content
: 实际Content
MsgType: 1 FromUserName: @@xxx ToUserName: @xxx Content: @xxx:<br/>xxx
MsgType: 49 AppMsgType: 2001 FromUserName: 发送方ID ToUserName: 接收方ID Content: 未知
MsgType: 10000 FromUserName: 发送方ID ToUserName: 本身ID Content: "你已添加了 xxx ,如今能够开始聊天了。" "若是陌生人主动添加你为朋友,请谨慎核实对方身份。" "收到红包,请在手机上查看"
tchat
为三种帐号都提供了 总体获取方法与搜索方法.
itchat.get_friends()
返回完整的好友列表
每一个好友为一个字典, 其中第一项为本人的帐号信息;
传入
update=True
, 将更新好友列表并返回,get_friends(update=True)
itchat.get_friends() 好友搜索,有如下四种方式
仅获取本身的用户信息
# 获取本身的用户信息,返回本身的属性字典 itchat.search_friends()
获取特定
UserName
的用户信息
# 获取特定UserName的用户信息 itchat.search_friends(userName='@abcdefg1234567') ## 获取发送信息的好友的详细信息 @itchat.msg_register(itchat.content.TEXT,isFriendChat=True) def reply(msg): print msg['FromUserName'] print itchat.search_friends(userName=msg['FromUserName']) #详细信息 print itchat.search_friends(userName=msg['FromUserName'])['NickName'] #获取昵称
获取备注,微信号, 昵称中的任何一项等于
name
键值的用户. (能够与下一项配置使用.)好比在个人微信中有一个备注为
autolife
的人,我可使用这个方法搜索出详细的信息
# 获取任何一项等于name键值的用户 itchat.search_friends(name='autolife')
获取备注,微信号, 昵称分别等于相应键值的用户. (能够与上一项配置使用.)
# 获取分别对应相应键值的用户 itchat.search_friends(wechatAccount='littlecodersh') # 3、四项功能能够一同使用 itchat.search_friends(name='LittleCoder机器人', wechatAccount='littlecodersh')
主要用于好友更新
特定用户: 传入用户
UserName
, 返回指定用户的最新信息.用户列表: 传入
UserName
组成的列表, 返回用户最新信息组成的列表
memberList = itchat.update_friend('@abcdefg1234567')
将返回完整的工做号列表
每一个公众号为一个字典,
传入
update=True
将更新公众号列表, 并返回.
获取特定
UserName
的公众号
# 获取特定UserName的公众号,返回值为一个字典 itchat.search_mps(userName='@abcdefg1234567')
获取名字中还有特定字符的公众号.
# 获取名字中含有特定字符的公众号,返回值为一个字典的列表 itchat.search_mps(name='LittleCoder')
当两项都是勇士, 将仅返回特定
UserName
的公众号.
get_chatrooms
: 返回完整的群聊列表.
search_chatrooms
: 群聊搜索.
update_chatroom
: 获取群聊用户列表或更新该群聊.
群聊在首次获取中不会获取群聊的用户列表, 因此须要调用该命令才能获取群聊成员.
传入群聊的
UserName
, 返回特定群聊的详细信息.传入
UserName
组成的列表, 返回指定用户的最新信息组成的列表.
memberList = itchat.update_chatroom('@@abcdefg1234567', detailedMember=True)
建立群聊,增长/删除群聊用户:
因为以前经过群聊检测是否被好友拉黑的程序, 目前这三个方法都被严格限制了使用频率.
删除群聊须要本帐号为管理员, 不然无效.
将用户加入群聊有直接加入与发送邀请, 经过
useInvitation
设置.超过 40 人的群聊没法使用直接加入的加入方式.
memberList = itchat.get_frients()[1:] # 建立群聊, topic 键值为群聊名称. chatroomUserName = itchat.create_chatroom(memberList, "test chatroom") # 删除群聊内的用户 itchat.delete_member_from_chatroom(chatroomUserName, memberList[0]) # 增长用户进入群聊. itchat.add_member_into_chatroom(chatroomUserName, memberList[0], useInvitation=False)
itchat.add_friend itchat.new_instance itchat.add_member_into_chatroom itchat.originInstance itchat.auto_login itchat.returnvalues itchat.check_login itchat.run itchat.components itchat.search_chatrooms itchat.config itchat.search_friends itchat.configured_reply itchat.search_mps itchat.content itchat.send itchat.core itchat.send_file itchat.Core itchat.send_image itchat.create_chatroom itchat.send_msg itchat.delete_member_from_chatroom itchat.send_raw_msg itchat.dump_login_status itchat.send_video itchat.get_chatrooms itchat.set_alias itchat.get_contact itchat.set_chatroom_name itchat.get_friends itchat.set_logging itchat.get_head_img itchat.set_pinned itchat.get_mps itchat.show_mobile_login itchat.get_msg itchat.start_receiving itchat.get_QR itchat.storage itchat.get_QRuuid itchat.update_chatroom itchat.instanceList itchat.update_friend itchat.load_login_status itchat.upload_file itchat.log itchat.utils itchat.login itchat.VERSION itchat.logout itchat.web_init itchat.msg_register
下面是博主写的一个程序,该程序的主要功能是监控撤回消息,而且若是有消息撤回就会撤回的消息发送给你,之后不再用担忧看不到好友的撤回的消息了,因为注释写的很详细,所以这里就不在详细的讲解了,直接贴代码
# coding:utf-8 import itchat from itchat.content import TEXT from itchat.content import * import sys import time import re reload(sys) sys.setdefaultencoding('utf8') import os msg_information = {} face_bug=None #针对表情包的内容 @itchat.msg_register([TEXT, PICTURE, FRIENDS, CARD, MAP, SHARING, RECORDING, ATTACHMENT, VIDEO],isFriendChat=True, isGroupChat=True, isMpChat=True) def handle_receive_msg(msg): global face_bug msg_time_rec = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()) #接受消息的时间 msg_from = itchat.search_friends(userName=msg['FromUserName'])['NickName'] #在好友列表中查询发送信息的好友昵称 msg_time = msg['CreateTime'] #信息发送的时间 msg_id = msg['MsgId'] #每条信息的id