一个玩微信的工具
Project description
WeChatFerry Python 客户端
📖 文档 | 📺 视频教程 | 🙋 FAQ |
---|---|---|
🤖示例机器人框架:WeChatRobot。 |
快速开始
pip install --upgrade wcferry
Demo:
#! /usr/bin/env python3
# -*- coding: utf-8 -*-
import logging
from threading import Thread
from time import sleep
from wcferry import Wcf
logging.basicConfig(level='DEBUG', format="%(asctime)s %(message)s")
LOG = logging.getLogger("Demo")
def process_msg(wcf: Wcf):
"""处理接收到的消息"""
while wcf.is_receiving_msg():
try:
msg = wcf.get_msg()
except Exception as e:
continue
LOG.info(msg) # 简单打印
def main():
LOG.info("Start demo...")
wcf = Wcf(debug=True) # 默认连接本地服务
sleep(5) # 等微信加载好,以免信息显示异常
LOG.info(f"已经登录: {True if wcf.is_login() else False}")
LOG.info(f"wxid: {wcf.get_self_wxid()}")
# 允许接收消息
# wcf.enable_recv_msg(LOG.info) # deprecated
# 允许接收消息
wcf.enable_receiving_msg()
Thread(target=process_msg, name="GetMessage", args=(wcf,), daemon=True).start()
# wcf.disable_recv_msg() # 当需要停止接收消息时调用
ret = wcf.send_text("Hello world.", "filehelper")
LOG.info(f"send_text: {ret}")
ret = wcf.send_image("TEQuant.jpeg", "filehelper") # 需要确保图片路径正确
LOG.info(f"send_image: {ret}")
ret = wcf.send_file("README.MD", "filehelper") # 需要确保文件路径正确
LOG.info(f"send_file: {ret}")
LOG.info(f"Message types:\n{wcf.get_msg_types()}")
LOG.info(f"Contacts:\n{wcf.get_contacts()}")
LOG.info(f"DBs:\n{wcf.get_dbs()}")
LOG.info(f"Tables:\n{wcf.get_tables('db')}")
LOG.info(f"Results:\n{wcf.query_sql('MicroMsg.db', 'SELECT * FROM Contact LIMIT 1;')}")
# 需要真正的 V3、V4 信息
# wcf.accept_new_friend("v3", "v4")
# 填写正确的群 ID 和成员 wxid
# ret = wcf.add_chatroom_members("chatroom id", "wxid1,wxid2,wxid3,...")
# LOG.info(f"add_chatroom_members: {ret}")
# 一直运行
wcf.keep_running()
if __name__ == "__main__":
main()
后台回复 WeChatFerry 加群交流 |
如果你觉得有用 |
一起开发
配置环境
# 创建虚拟环境
python -m venv .env
# 激活虚拟环境
source .env/Scripts/activate
# 升级 pip
pip install --upgrade pip
# 安装依赖包
pip install grpcio-tools pynng
重新生成 PB 文件
# CMD
cd python\wcferry
python -m grpc_tools.protoc --python_out=. --proto_path=..\..\rpc\proto\ wcf.proto
# GitBash
cd python/wcferry
python -m grpc_tools.protoc --python_out=. --proto_path=../../rpc/proto/ wcf.proto
版本更新
版本号: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 开始
39.0.0.0a0 (2023.07.11)
支持微信 3.9.2.23
。
功能:
- 检查登录状态
- 获取登录账号的 wxid
- 获取消息类型
- 获取所有联系人
- 获取所有好友
- 获取数据库
- 获取某数据库下的表
- 发送文本消息(可 @)
- 发送图片(Python 客户端支持网络路径)
- 发送文件
- 允许接收消息
- 停止接收消息
- 执行 SQL 查询
- 接受好友申请
- 添加群成员
- 解密图片
- 某功能(Breaking Change)
历史更新
37.1.25.5 (2023.05.19)
支持 3.7.0.30
的最后一个版本。
功能:
- 检查登录状态
- 获取登录账号的 wxid
- 获取消息类型
- 获取所有联系人
- 获取所有好友
- 获取数据库
- 获取某数据库下的表
- 发送文本消息(可 @)
- 发送图片(Python 客户端支持网络路径)
- 发送文件
- 发送 XML
- 发送表情
- 允许接收消息
- 停止接收消息
- 执行 SQL 查询
- 接受好友申请
- 添加群成员
- 解密图片
- 某功能
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
wcferry-39.0.0.0a0.tar.gz
(883.7 kB
view hashes)
Built Distribution
wcferry-39.0.0.0a0-py3-none-any.whl
(883.1 kB
view hashes)
Close
Hashes for wcferry-39.0.0.0a0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2d9ca48ed0977530829200281a26d71dcb277d86349de2b96b021b0a7e63ec6b |
|
MD5 | b41ad22b2af1e19778692dbf2e1642dd |
|
BLAKE2b-256 | 14203121d749ce5afdb5eb1c30c06bf75fe2c2ce8811b0bccba2a644d79b6919 |