itchat 是一个开源的微信个人号接口。
近期完成了 py3 与文档的完善,欢迎各位使用与测试。
使用不到三十行的代码,你就可以完成一个能够处理所有信息的微信机器人。
当然,该 api 的使用远不止一个机器人,更多的功能等着你来发现。
如今微信已经成为了个人社交的很大一部分,希望这个项目能够帮助你扩展你的个人的微信号、方便自己的生活。
可以通过本命令安装 itchat :
pip install itchat
有了 itchat ,如果你想要回复发给自己的文本消息,只需要这样:
import itchat @itcaht.msg_register(itchat.content.TEXT) def text_reply(msg): itchat.send(msg['Text'], msg['FromUserName']) itchat.auto_login() itchat.run()
一些进阶应用可以在 Advanced uses 中看到,或者你也可以阅览文档。
这是一个基于这一项目的开源小机器人,百闻不如一见,有兴趣可以尝试一下。
通过如下代码,微信已经可以就日常的各种信息进行获取与回复。
#coding=utf8 import itchat, time from itchat.content import * @itchat.msg_register([TEXT, MAP, CARD, NOTE, SHARING]) def text_reply(msg): itchat.send('%s: %s' % (msg['Type'], msg['Text']), msg['FromUserName']) @itchat.msg_register([PICTURE, RECORDING, ATTACHMENT, VIDEO]) def download_files(msg): msg['Text'](msg['FileName']) return '@%s@%s' % ({'Picture': 'img', 'Video': 'vid'}.get(msg['Type'], 'fil'), msg['FileName']) @itchat.msg_register(FRIENDS) def add_friend(msg): itchat.add_friend(**msg['Text']) # 该操作会自动将新好友的消息录入,不需要重载通讯录 itchat.send_msg('Nice to meet you!', msg['RecommendInfo']['UserName']) @itchat.msg_register(TEXT, isGroupChat=True) def text_reply(msg): if msg['isAt']: itchat.send(u'@%s\u2005I received: %s' % (msg['ActualNickName'], msg['Content']), msg['FromUserName']) itchat.auto_login(True) itchat.run()
通过以下命令可以在登陆的时候使用命令行显示二维码:
itchat.auto_login(enableCmdQR=True)
部分系统可能字幅宽度有出入,可以通过将 enableCmdQR 赋值为特定的倍数进行调整:
# 如部分的 linux 系统,块字符的宽度为一个字符(正常应为两字符),故赋值为 2 itchat.auto_login(enableCmdQR=2)
默认控制台背景色为暗色(黑色),若背景色为浅色(白色),可以将 enableCmdQR 赋值为负值:
itchat.auto_login(enableCmdQR=-1)
通过如下命令登陆,即使程序关闭,一定时间内重新开启也可以不用重新扫码。
itchat.auto_login(hotReload=True)
使用get_friends
方法可以搜索用户,有四种搜索方式:
UserName
的用户信息name
键值的用户其中三、四项可以一同使用,下面是示例程序:
# 获取自己的用户信息,返回自己的属性字典 itchat.get_friends() # 获取特定 UserName 的用户信息 itchat.get_friends(userName='@abcdefg1234567') # 获取任何一项等于 name 键值的用户 itchat.get_friends(name='littlecodersh') # 获取分别对应相应键值的用户 itchat.get_friends(wechatAccount='littlecodersh') # 三、四项功能可以一同使用 itchat.get_friends(name='LittleCoder 机器人', wechatAccount='littlecodersh')
itchat 的附件下载方法存储在 msg 的 Text 键中。
发送的文件的文件名(图片给出的默认文件名)都存储在 msg 的 FileName 键中。
下载方法接受一个可用的位置参数(包括文件名),并将文件相应的存储。
@itchat.msg_register(['Picture', 'Recording', 'Attachment', 'Video']) def download_files(msg): msg['Text'](msg['FileName']) itchat.send('@%s@%s'%('img' if msg['Type'] == 'Picture' else 'fil', msg['FileName']), msg['FromUserName']) return '%s received'%msg['Type']
如果你不需要下载到本地,仅想要读取二进制串进行进一步处理可以不传入参数,方法将会返回图片的二进制串。
@itchat.msg_register(['Picture', 'Recording', 'Attachment', 'Video']) def download_files(msg): with open(msg['FileName'], 'wb') as f: f.write(msg['Text']())
Q: 为什么中文的文件没有办法上传?
A: 这是由于requests
的编码问题导致的。若需要支持中文文件传输,将fields.py(py3 版本见这里)文件放入 requests 包的 packages/urllib3 下即可
Q: 为什么我在设定了itchat.auto_login()
的enableCmdQR
为True
后还是没有办法在命令行显二维码?
A: 这是由于没有安装可选的包pillow
,可以使用右边的命令安装:pip install pillow
Q: 如何通过这个包将自己的微信号变为控制器?
A: 有两种方式:发送、接受自己 UserName 的消息;发送接收文件传输助手( filehelper )的消息
如果有什么问题或者建议都可以在这个Issue和我讨论
![]() | 1 uucloud 2016-09-17 22:35:37 +08:00 po 主知道微信第三方验证的时候那个 code 字段是怎么得到的吗?可不可以直接通过 python 完成和微信第三方的交互,比如签到。 |
2 bearqq 2016-09-17 22:45:10 +08:00 via Android 上周才用这个搞了个微信端 bot ,接 char-rnn 神经网络,折腾着玩。 挺稳定,没掉过。 要说不满的话,命令行的二维码太大,我得退几步才能扫码。。 |
![]() | 3 airqj 2016-09-17 22:53:11 +08:00 已 start :) |
![]() | 4 bao3 2016-09-18 00:28:09 +08:00 via Android 赞 |
![]() | 5 heiybb 2016-09-18 00:31:41 +08:00 赞,最近的小玩具应该会用上,已 STAR |
![]() | 6 dreamcog 2016-09-18 00:34:09 +08:00 via iPhone 赞 |
![]() | 7 fy 2016-09-18 01:53:24 +08:00 资瓷 收藏一发 |
8 ben3ai 2016-09-18 07:05:43 +08:00 via iPhone 资瓷 收藏一发 |
9 pubuntu 2016-09-18 08:28:22 +08:00 via Android 非常好。赞赞 |
![]() | 10 Gothack 2016-09-18 08:44:37 +08:00 via iPhone 好东西 果断收藏 |
![]() | 11 NxnXgpuPSfsIT OP @uucloud 不知道,这方面没有做过研究。 |
![]() | 12 NxnXgpuPSfsIT OP @bearqq 命令行显示的话是会有些大,因为为了达到最大的兼容,用的字符的形式拼成的二维码。 如果想要二维码小一些的话可以试试看直接显示图片或者自定义登录过程。 |
![]() | 13 omegatao 2017-04-18 20:37:59 +08:00 非常非常赞 |
![]() | 14 randix 2017-06-12 16:17:22 +08:00 get_friends 这个方法是搜索本地的用户的吗? |
![]() | 15 HanningWu 2017-06-21 16:52:13 +08:00 add_friends 是用于添加新好友? |