WeChatFerry/clients/wcfautopy/README.MD

164 lines
5.1 KiB
Plaintext
Raw Normal View History

# WeChatFerry wcfautopy 客户端(基于python客户端进行修改)
[![PyPi](https://img.shields.io/pypi/v/wcferry.svg)](https://pypi.python.org/pypi/wcferry) [![Downloads](https://static.pepy.tech/badge/wcferry)](https://pypi.python.org/pypi/wcferry) [![Documentation Status](https://readthedocs.org/projects/wechatferry/badge/?version=latest)](https://wechatferry.readthedocs.io/zh/latest/?badge=latest)
|[📖 文档](https://wechatferry.readthedocs.io/)|[📺 视频教程](https://mp.weixin.qq.com/s/APdjGyZ2hllXxyG_sNCfXQ)|[🙋 FAQ](https://mp.weixin.qq.com/s/vAGpn1C9stI8Xzt1hUJhLA)|
|:-:|:-:|:-:|
🤖示例机器人框架:[WeChatRobot](https://github.com/lich0821/WeChatRobot)。
## 快速开始
```sh
pip install --upgrade wcferry
```
### Demo
```py
#! /usr/bin/env python3
# -*- coding: utf-8 -*-
import logging
from time import sleep
from wcferry import Wcf, WxMsg, Register
logging.basicConfig(level='DEBUG', format="%(asctime)s %(message)s")
LOG = logging.getLogger("Demo")
def main():
receiver = Register()
@receiver.message_register(isDivision=True, isGroup=True, isPyq=False)
def process_msg(bot: Wcf, msg: WxMsg):
"""
同步消息函数装饰器
"""
LOG.info(f"收到消息: {msg}")
sleep(5) # 等微信加载好,以免信息显示异常
LOG.info(f"已经登录: {True if bot.is_login() else False}")
LOG.info(f"wxid: {bot.get_self_wxid()}")
# bot.disable_recv_msg() # 当需要停止接收消息时调用
sleep(5)
ret = bot.send_text("Hello world.", "filehelper")
LOG.info(f"send_text: {ret}")
sleep(5)
# 需要确保图片路径正确,建议使用绝对路径(使用双斜杠\\
ret = bot.send_image("https://raw.githubusercontent.com/lich0821/WeChatFerry/master/assets/QR.jpeg", "filehelper")
LOG.info(f"send_image: {ret}")
sleep(5)
# 需要确保文件路径正确,建议使用绝对路径(使用双斜杠\\
ret = bot.send_file("https://raw.githubusercontent.com/lich0821/WeChatFerry/master/README.MD", "filehelper")
LOG.info(f"send_file: {ret}")
sleep(5)
LOG.info(f"Message types:\n{bot.get_msg_types()}")
LOG.info(f"Contacts:\n{bot.get_contacts()}")
sleep(5)
LOG.info(f"DBs:\n{bot.get_dbs()}")
LOG.info(f"Tables:\n{bot.get_tables('db')}")
LOG.info(f"Results:\n{bot.query_sql('MicroMsg.db', 'SELECT * FROM Contact LIMIT 1;')}")
# 需要真正的 V3、V4 信息
# bot.accept_new_friend("v3", "v4")
# 添加群成员,填写正确的群 ID 和成员 wxid
# ret = bot.add_chatroom_members("chatroom id", "wxid1,wxid2,wxid3,...")
# LOG.info(f"add_chatroom_members: {ret}")
# 删除群成员,填写正确的群 ID 和成员 wxid
# ret = bot.del_chatroom_members("chatroom id", "wxid1,wxid2,wxid3,...")
# LOG.info(f"add_chatroom_members: {ret}")
sleep(5)
bot.refresh_pyq(0) # 刷新朋友圈第一页
# bot.refresh_pyq(id) # 从 id 开始刷新朋友圈
@receiver.async_message_register()
async def async_process_msg(bot: Wcf, msg: WxMsg):
"""
异步消息函数装饰器
"""
print(msg)
# 开始接受消息
receiver.run()
if __name__ == "__main__":
main()
```
|![碲矿](https://raw.githubusercontent.com/lich0821/WeChatFerry/master/assets/TEQuant.jpg)|![赞赏](https://raw.githubusercontent.com/lich0821/WeChatFerry/master/assets/QR.jpeg)|
|:-:|:-:|
|后台回复 `WeChatFerry` 加群交流|如果你觉得有用|
## 一起开发
### 配置环境
```sh
# 创建虚拟环境
python -m venv .env
# 激活虚拟环境
source .env/Scripts/activate
# 升级 pip
pip install --upgrade pip
# 安装依赖包
pip install grpcio-tools pynng
```
### 重新生成 PB 文件
```sh
# CMD
cd clients\wcfautopy\wcferry
python -m grpc_tools.protoc --python_out=. --proto_path=..\..\..\WeChatFerry\rpc\proto\ wcf.proto
# GitBash
cd clients/wcfautopy/wcferry
python -m grpc_tools.protoc --python_out=. --proto_path=../../../WeChatFerry/rpc/proto/ wcf.proto
```
## 版本更新
### 39.0.3.0 (2023.09.28)
* 修复登录账号昵称超长报错问题
<details><summary>点击查看更多</summary>
版本号:`w.x.y.z`。
其中:
* `w` 是微信的大版本号,如 `37` (3.7.a.a), `38` (3.8.a.a), `39` (3.9.a.a)
* `x` 是适配的微信的小版本号,从 0 开始
* `y` 是 `WeChatFerry` 的版本,从 0 开始
* `z` 是各客户端的版本,从 0 开始
功能:
* 检查登录状态
* 获取登录账号的 wxid
* 获取消息类型
* 获取所有联系人
* 获取所有好友
* 获取数据库
* 获取某数据库下的表
* 获取用户信息
* 发送文本消息(可 @
* 发送图片wcfautopy 客户端支持网络路径)
* 发送文件wcfautopy 客户端支持网络路径)
* 允许接收消息
* 停止接收消息
* 执行 SQL 查询
* 接受好友申请
* 添加群成员
* 删除群成员
* 解密图片
* 获取朋友圈消息
* 某功能Breaking Change
</details>