|
@@ -1,6 +1,32 @@
|
|
|
# wxBot [](http://github.com/liuwons/wxBot) [](http://github.com/liuwons/wxBot/fork) 
|
|
|
|
|
|
-Python包装Web微信实现的微信机器人框架。可以很容易地实现微信机器人。
|
|
|
+**wxBot** 是用Python包装Web微信协议实现的微信机器人框架。
|
|
|
+
|
|
|
+目前的消息支持情况:
|
|
|
+
|
|
|
+- [ ] 群消息
|
|
|
+ - [x] 文本
|
|
|
+ - [x] 图片
|
|
|
+ - [x] 地理位置
|
|
|
+ - [x] 个人名片
|
|
|
+ - [x] 语音
|
|
|
+ - [x] 动画
|
|
|
+ - [ ] 语音电话
|
|
|
+ - [ ] 红包
|
|
|
+
|
|
|
+- [ ] 联系人消息
|
|
|
+ - [x] 文本
|
|
|
+ - [x] 图片
|
|
|
+ - [x] 地理位置
|
|
|
+ - [x] 个人名片
|
|
|
+ - [x] 语音
|
|
|
+ - [x] 小视频
|
|
|
+ - [x] 动画
|
|
|
+ - [ ] 视频电话
|
|
|
+ - [ ] 红包
|
|
|
+ - [ ] 转账
|
|
|
+
|
|
|
+
|
|
|
|
|
|
Web微信协议参考资料:
|
|
|
|
|
@@ -10,10 +36,14 @@ Web微信协议参考资料:
|
|
|
|
|
|
[qwx: WeChat Qt frontend 微信Qt前端](https://github.com/xiangzhai/qwx)
|
|
|
|
|
|
+
|
|
|
## 1 环境与依赖
|
|
|
|
|
|
目前只能运行于Python 2环境 。
|
|
|
-**wxBot** 用到了Python **requests** , **pypng** , 以及 **pyqrcode** 库,使用之前需要安装这三个库:
|
|
|
+
|
|
|
+**wxBot** 用到了Python **requests** , **pypng** , 以及 **pyqrcode** 库。
|
|
|
+
|
|
|
+使用之前需要所依赖的库:
|
|
|
|
|
|
```bash
|
|
|
pip install requests
|
|
@@ -22,13 +52,14 @@ pip install pypng
|
|
|
```
|
|
|
|
|
|
## 2 快速开发
|
|
|
-### 2.1 代码
|
|
|
|
|
|
-利用 **wxBot** 最简单的方法就是继承WXBot类并实现handle_msg_all或者schedule函数,然后实例化子类并run。
|
|
|
+利用 **wxBot** 最简单的方法就是继承WXBot类并实现 `handle_msg_all` 或者 `schedule` 函数,然后实例化子类并调用 `run` 方法 。
|
|
|
+
|
|
|
+### 2.1 代码
|
|
|
|
|
|
-以下的代码对所有来自好友的文本消息回复 "hi", 并不断向好友tb发送"schedule"。
|
|
|
+以下的代码对所有来自好友的文本消息回复 *hi* , 并不断向好友 *tb* 发送 *schedule* 。
|
|
|
|
|
|
-handle_msg_all函数用于处理收到的每条消息,而schedule函数可以做一些任务性的事情(例如不断向好友推送信息或者一些定时任务)。
|
|
|
+`handle_msg_all` 函数用于处理收到的每条消息,而 `schedule` 函数可以做一些任务性的事情(例如不断向好友推送信息或者一些定时任务)。
|
|
|
|
|
|
```python
|
|
|
#!/usr/bin/env python
|
|
@@ -58,7 +89,7 @@ if __name__ == '__main__':
|
|
|
|
|
|
### 2.2 运行
|
|
|
|
|
|
-直接用python运行代码(如运行测试代码test.py):
|
|
|
+直接用 `python` 运行代码(如运行测试代码 ***test.py*** ):
|
|
|
|
|
|
``` python
|
|
|
python test.py
|
|
@@ -66,58 +97,58 @@ python test.py
|
|
|
|
|
|
### 2.3 登录微信
|
|
|
|
|
|
-程序运行之后,会在当前目录下生成二维码图片文件 qr.png ,用微信扫描此二维码并按操作指示确认登录网页微信。
|
|
|
+程序运行之后,会在当前目录下生成二维码图片文件 ***qr.png*** ,用微信扫描此二维码并按操作指示确认登录网页微信。
|
|
|
|
|
|
-如果运行在Linux下,还可以通过设置WXBot对象的conf['qr']为'tty'的方式直接在终端打印二维码(此方法只能在Linux终端下使用),效果如下:
|
|
|
+如果运行在Linux下,还可以通过设置 **WXBot** 对象的 `conf['qr']` 为 `tty` 的方式直接在终端打印二维码(此方法只能在Linux终端下使用),效果如下:
|
|
|
|
|
|

|
|
|
|
|
|
## 3 效果展示
|
|
|
|
|
|
-测试代码test.py的运行效果:
|
|
|
+测试代码 ***test.py*** 的运行效果:
|
|
|
|
|
|

|
|
|
|
|
|

|
|
|
|
|
|
## 4 接口
|
|
|
-### 4.1 handle_msg_all
|
|
|
+### 4.1 `handle_msg_all`
|
|
|
|
|
|
-handle_msg_all函数的参数msg是代表一条消息的字典。字段的内容为:
|
|
|
+`handle_msg_all` 函数的参数 `msg` 是代表一条消息的字典。字段的内容为:
|
|
|
|
|
|
| 字段名 | 字段内容 |
|
|
|
| ----- | --- |
|
|
|
-| msg_type_id | 整数,消息类型,具体解释可以查看 **消息类型表** |
|
|
|
-| msg_id | 字符串,消息id |
|
|
|
-| content | 字典,消息内容,具体含有的字段请参考 **消息类型表** ,一般含有type(数据类型)与data(数据内容)字段,type与data的对应关系可以参考 **数据类型表** |
|
|
|
-| user | 字典,消息来源,字典包含name(发送者名称,如果是群则为群名称,如果为微信号,有备注则为备注名,否则为微信号或者群昵称)字段与id(发送者id)字段,都是字符串 |
|
|
|
+| `msg_type_id` | 整数,消息类型,具体解释可以查看 **消息类型表** |
|
|
|
+| `msg_id` | 字符串,消息id |
|
|
|
+| `content` | 字典,消息内容,具体含有的字段请参考 **消息类型表** ,一般含有 `type`(数据类型)与 `data`(数据内容)字段,`type` 与 `data`的对应关系可以参考 **数据类型表** |
|
|
|
+| `user` | 字典,消息来源,字典包含 `name`(发送者名称,如果是群则为群名称,如果为微信号,有备注则为备注名,否则为微信号或者群昵称)字段与 `id`(发送者id)字段,都是字符串 |
|
|
|
|
|
|
|
|
|
### 4.2 消息类型表
|
|
|
|
|
|
-| 类型号 | 消息类型 | content |
|
|
|
+| 类型号 | 消息类型 | `content` |
|
|
|
| ----- | --- | ------ |
|
|
|
| 0 | 初始化消息,内部数据 | 无意义,可以忽略 |
|
|
|
| 1 | 自己发送的消息 | 无意义,可以忽略 |
|
|
|
-| 2 | 文件消息 | 字典,包含type与data字段 |
|
|
|
-| 3 | 群消息 | 字典, 包含user(字典,包含id与name字段,都是字符串,表示发送此消息的群用户)与type、data字段,红包消息除外(只有type字段) |
|
|
|
-| 4 | 联系人消息 | 字典,包含type与data字段 |
|
|
|
-| 5 | 公众号消息 | 字典,包含type与data字段 |
|
|
|
-| 6 | 特殊账号消息 | 字典,包含type与data字段 |
|
|
|
+| 2 | 文件消息 | 字典,包含 `type` 与 `data` 字段 |
|
|
|
+| 3 | 群消息 | 字典, 包含 `user` (字典,包含 `id` 与 `name`字段,都是字符串,表示发送此消息的群用户)与 `type` 、 `data` 字段,红包消息除外(只有 `type` 字段) |
|
|
|
+| 4 | 联系人消息 | 字典,包含 `type` 与 `data` 字段 |
|
|
|
+| 5 | 公众号消息 | 字典,包含 `type` 与 `data` 字段 |
|
|
|
+| 6 | 特殊账号消息 | 字典,包含 `type` 与 `data` 字段 |
|
|
|
| 99 | 未知账号消息 | 无意义,可以忽略 |
|
|
|
|
|
|
|
|
|
### 4.3 数据类型表
|
|
|
|
|
|
-| type | 数据类型 | data |
|
|
|
+| `type` | 数据类型 | `data` |
|
|
|
| ---- | ---- | ------ |
|
|
|
| 0 | 文本 | 字符串,表示文本消息的具体内容 |
|
|
|
| 1 | 地理位置 | 字符串,表示地理位置 |
|
|
|
-| 3 | 图片 | 字符串,图片数据的url,HTTP POST得到jpg文件格式的数据 |
|
|
|
-| 4 | 语音 | 字符串,语音数据的url,HTTP POST得到mp3文件格式的数据 |
|
|
|
-| 5 | 名片 | 字典,包含nickname(昵称),alias(别名),province(省份),city(城市), gender(性别)字段 |
|
|
|
-| 6 | 动画 | 字符串, 动画url |
|
|
|
-| 7 | 分享 | 字典,包含type(类型),title(标题),desc(描述),url(链接),from(来自)字段 |
|
|
|
+| 3 | 图片 | 字符串,图片数据的url,HTTP POST请求此url可以得到jpg文件格式的数据 |
|
|
|
+| 4 | 语音 | 字符串,语音数据的url,HTTP POST请求此url可以得到mp3文件格式的数据 |
|
|
|
+| 5 | 名片 | 字典,包含 `nickname` (昵称), `alias` (别名),`province` (省份),`city` (城市), `gender` (性别)字段 |
|
|
|
+| 6 | 动画 | 字符串, 动画url, HTTP POST请求此url可以得到mp3文件格式的数据 |
|
|
|
+| 7 | 分享 | 字典,包含 `type` (类型),`title` (标题),`desc` (描述),`url` (链接),`from` (源网站)字段 |
|
|
|
| 8 | 视频 | 不可用 |
|
|
|
| 9 | 视频电话 | 不可用 |
|
|
|
| 10 | 撤回消息 | 不可用 |
|
|
@@ -128,36 +159,36 @@ handle_msg_all函数的参数msg是代表一条消息的字典。字段的内容
|
|
|
|
|
|
### 4.4 WXBot对象属性
|
|
|
|
|
|
-WXBot对象在登录并初始化之后,含有以下的可用数据:
|
|
|
+**WXBot** 对象在登录并初始化之后,含有以下的可用数据:
|
|
|
|
|
|
| 属性 | 描述 |
|
|
|
| ---- | ---- |
|
|
|
-| contact_list | 当前用户的微信联系人列表 |
|
|
|
-| group_list | 当前用户的微信群列表 |
|
|
|
-| public_list | 当前用户关注的公众号列表 |
|
|
|
-| special_list | 特殊账号列表 |
|
|
|
-| session | WXBot与WEB微信服务器端交互所用的requests Session对象 |
|
|
|
+| `contact_list` | 当前用户的微信联系人列表 |
|
|
|
+| `group_list` | 当前用户的微信群列表 |
|
|
|
+| `public_list` | 当前用户关注的公众号列表 |
|
|
|
+| `special_list` | 特殊账号列表 |
|
|
|
+| `session` | **WXBot** 与WEB微信服务器端交互所用的 **Requests** `Session` 对象 |
|
|
|
|
|
|
### 4.5 WXBot对象方法
|
|
|
|
|
|
-WXBot对象还含有一些可以利用的方法
|
|
|
+**WXBot** 对象还含有一些可以利用的方法
|
|
|
|
|
|
| 方法 | 描述 |
|
|
|
| ---- | --- |
|
|
|
-| get_icon(id) | 获取用户icon并保存到本地文件 img_[id].jpg ,id为用户id(Web微信数据) |
|
|
|
-| get_head_img(id) | 获取用户头像并保存到本地文件 img_[id].jpg,id为用户id(Web微信数据) |
|
|
|
-| get_msg_img(msgid) | 获取图像消息并保存到本地文件 img_[msgid].jpg, msgid为消息id(Web微信数据) |
|
|
|
-| get_voice(msgid) | 获取语音消息并保存到本地文件 voice_[msgid].mp3, msgid为消息id(Web微信数据) |
|
|
|
-| get_account_name(uid) | 获取微信id对应的名称,返回一个可能包含remark_name(备注名),nickname(昵称), display_name(群名称)的字典|
|
|
|
-| send_msg_by_uid(word, dst) | 向好友发送消息,word为消息字符串,dst为好友用户id(Web微信数据) |
|
|
|
-| send_msg(name, word, isfile) | 向好友发送消息,name为好友的备注名或者好友微信号,isfile为False时word为消息,isfile为True时word为文件路径(此时向好友发送文件里的每一行) |
|
|
|
-| is_contact(uid) | 判断id为uid的账号是否是本帐号的好友,返回True(是)或False(不是) |
|
|
|
-| is_public(uid) | 判断id为uid的账号是否是本帐号所关注的公众号,返回True(是)或False(不是) |
|
|
|
+| `get_icon(id)` | 获取用户icon并保存到本地文件 ***img_[id].jpg*** , `id` 为用户id(Web微信数据) |
|
|
|
+| `get_head_img(id)` | 获取用户头像并保存到本地文件 ***img_[id].jpg*** ,`id` 为用户id(Web微信数据) |
|
|
|
+| `get_msg_img(msgid)` | 获取图像消息并保存到本地文件 ***img_[msgid].jpg*** , `msgid` 为消息id(Web微信数据) |
|
|
|
+| `get_voice(msgid)` | 获取语音消息并保存到本地文件 ***voice_[msgid].mp3*** , `msgid` 为消息id(Web微信数据) |
|
|
|
+| `get_account_name(uid)` | 获取微信id对应的名称,返回一个可能包含 `remark_name` (备注名), `nickname` (昵称), `display_name` (群名称)的字典|
|
|
|
+| `send_msg_by_uid(word, dst)` | 向好友发送消息,`word` 为消息字符串,`dst` 为好友用户id(Web微信数据) |
|
|
|
+| `send_msg(name, word, isfile)` | 向好友发送消息,`name` 为好友的备注名或者好友微信号, `isfile`为 `False` 时 `word` 为消息,`isfile` 为 `True` 时 `word` 为文件路径(此时向好友发送文件里的每一行) |
|
|
|
+| `is_contact(uid)` | 判断id为 `uid` 的账号是否是本帐号的好友,返回 `True` (是)或 `False` (不是) |
|
|
|
+| `is_public(uid)` | 判断id为 `uid` 的账号是否是本帐号所关注的公众号,返回 `True` (是)或 `False` (不是) |
|
|
|
|
|
|
|
|
|
## 5 Example
|
|
|
|
|
|
-bot.py 用 **[图灵机器人](http://www.tuling123.com/)** API 以及 **wxBot** 实现了一个自动回复机器人.
|
|
|
+***bot.py*** 用 **[图灵机器人](http://www.tuling123.com/)** API 以及 **wxBot** 实现了一个自动回复机器人.
|
|
|
|
|
|
此机器人会回复来自联系人的消息,以及群里@此账号的消息。
|
|
|
|
|
@@ -168,12 +199,15 @@ bot.py 用 **[图灵机器人](http://www.tuling123.com/)** API 以及 **wxBot**
|
|
|

|
|
|
|
|
|
|
|
|
-bot.py的运行方法:
|
|
|
+***bot.py*** 的运行方法:
|
|
|
1. 在[图灵机器人官网](http://www.tuling123.com/)注册账号,申请图灵key: [图灵key申请地址](http://www.tuling123.com/html/doc/apikey.html)
|
|
|
- 2. 在bot.py文件所在目录下新建conf.ini文件,内容为(key字段内容为申请到的图灵key):
|
|
|
+ 2. 在 ***bot.py*** 文件所在目录下新建 ***conf.ini*** 文件,内容为:(key字段内容为申请到的图灵key)
|
|
|
|
|
|
```txt
|
|
|
[main]
|
|
|
key=1d2678900f734aa0a23734ace8aec5b1
|
|
|
```
|
|
|
- 3. 运行bot.py
|
|
|
+ 3. 运行 ***bot.py***
|
|
|
+ ```python
|
|
|
+ python bot.py
|
|
|
+ ```
|