# pywechat **Repository Path**: java_superb/pywechat ## Basic Information - **Project Name**: pywechat - **Description**: No description available - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: main - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 1 - **Forks**: 0 - **Created**: 2025-07-24 - **Last Updated**: 2025-09-24 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # pywechat🥇 ![image](https://github.com/Hello-Mr-Crab/pywechat/blob/main/pics/introduction.jpg) ## 🍬🍬全网最强微信RPA! ### pywechat是一个基于pywinauto实现的Windows系统下PC微信自动化的Python项目。基本实现了PC微信内置的所有功能,支持单线程多任务轮流进行!! ### 微信版本:3.9.12.xx , 4.0+(只有简单的消息发送功能) ### 操作系统:🪟windows 10 🪟windows 11 ### python版本🐍:3.x ### 支持语言:简体中文,English,繁体中文 ### pywechat项目结构: ![image](https://github.com/Hello-Mr-Crab/pywechat/blob/main/pics/pywechat结构图.png)
## 新版本pywechat内所有模块下的类或函数均可直接从pywechat导入,使用两行代码即可实现从自动登录到自动回复的一系列微信自动化之旅。🗺️🗺️ ``` from pywechat import xx(class) from pywechat import xx(function) ```
### 注意:针对未登录的情况,pywechat最新版本会通过查询环境变量,注册表等一些方法尽可能地自动找到微信路径,除非你的微信路径手动修改过,发生了变动的话可能需要将微信路径加入到环境变量或手动传入
### 获取方法: #### 最新版本:1.9.6 ``` pip install pywechat127==1.9.6 ```
``` pip install --upgrade pywechat127 ```
### 添加微信至windows用户环境变量: #### pywechat已内置自动添加微信至用户环境变量的方法,运行下列代码即可自动添加微信路径至windows用户变量 : ``` from pywechat.WechatTools import Tools Tools.set_wechat_as_environ_path() ``` #### 效果演示: ![Alt text](https://github.com/Hello-Mr-Crab/pywechat/blob/main/pics/演示效果.gif)
### WechatTools🌪️🌪️ #### 模块包括: #### Tools:关于PC微信的一些工具,包括打开PC微信内各个界面的open系列方法。 #### API:打开指定微信小程序,指定公众号,打开视频号的功能,若有其他开发者想自动化操作上述程序可调用此API。 #### 函数:该模块内所有函数与方法一致。
### WechatAuto🛏️🛏️ #### 模块包括: ##### Messages: 5种类型的发送消息方法,包括:单人单条,单人多条,多人单条,多人多条,转发消息:多人同一条。 ##### Files: 5种类型的发送文件方法,包括:单人单个,单人多个,多人单个,多人多个,转发文件:多人同一个。发送多个文件时,你只需将所有文件放入文件夹内,将文件夹路径传入即可。 ##### FriendSettings: 涵盖了PC微信针对某个好友的全部操作的方法。 ##### GroupSettings: 涵盖了PC微信针对某个群聊的全部操作的方法。 ##### Contacts: 获取3种类型通讯录好友的备注与昵称包括:微信好友,企业号微信,群聊名称与人数,数据返回格式为json。 ##### Call: 给某个好友打视频或语音电话。 ##### AutoReply:自动接听微信视频或语音电话,自动回复指定好友消息,自动回复所有好友消息。 #### 函数:该模块内所有函数与方法一致。
### WinSettings🔹🔹 #### 模块包括: #### Systemsettings:该模块中提供了一些修改windows系统设置的方法。 #### 函数:该模块内所有函数与方法一致。
### 使用示例: #### 所有自动化操作只需两行代码即可实现,即: ``` from pywechat import xxx xxx ```
#### (注意,微信WeChat.exe路径已添加至windows系统环境变量,故当微信还未登录时,以下方法或函数无需传入wechat_path这一参数) #### 监听某个群聊或好友的窗口(自动保存聊天文件与图片和视频) ``` from pywechat import listen_on_chat filesave_folder=r"E:\Desktop\保存文件" mediasave_folder=r"E:\Desktop\聊天图片与视频保存" contents,senders,types=listen_on_chat(friend='测试群',duration='10min',save_file=True,file_folder=filesave_folder,save_media=True,media_folder=mediasave_folder) print(contents,senders,types) ``` #### 监听整个会话列表内所有好友的新消息(自动保存聊天文件) ``` from pywechat import check_new_message filesave_folder=r"E:\Desktop\文件保存" newMessages=check_new_message(duration='5min',save_file=True,target_folder=filesave_folder) #newMessages是[{'好友名称':'路人甲','好友类型':'群聊,好友或公众号','新消息条数':xx,'消息内容':[],'消息类型':[]}] #格式的list[dict] ``` ##### 运行效果可查看 https://blog.csdn.net/weixin_73953650/article/details/148619622?spm=1001.2014.3001.5501 #### 转发指定数量文件给n个好友 ``` #注意:微信转发消息单次上线为9,pywechat内转发消息,文件,链接,小程序等支持多个好友按9个为一组分批发送 from pywechat import forward_files others=['路人甲','路人乙','路人丙','路人丁'] forward_files(friend='测试群',others=others,number=20) ``` #### 保存指定数量聊天文件到本地] ``` from pywechat import save_files folder_path=r'E:\Desktop\新建文件夹' save_files(friend='测试群',number=20,folder_path=folder_path) ``` #### 群聊内自动回复(被@时触发) ``` from pywechat import auto_reply_to_group auto_reply_to_group(group_name='测试群',duration='20min',content='我被@了',at_only=True,at_others=True) ``` #### 给某个好友发送多条信息: ``` from pywechat.WechatAuto import Messages Messages.send_messages_to_friend(friend="文件传输助手",messages=['你好','我正在使用pywechat操控微信给你发消息','收到请回复']) ``` ##### 或者 ``` import pywechat.WechatAuto as wechat wechat.send_messages_to_friend(friend="文件传输助手",messages=['你好','我正在使用pywechat操控微信给你发消息','收到请回复']) ```
#### 自动接听语音视频电话: ``` from pywechat.WechatAuto import AutoReply AutoReply.auto_answer_call(broadcast_content='您好,我目前不在线我的PC微信正在由我的微信机器人控制请稍后再试',message='您好,我目前不在线我的PC微信正在由我的微信机器人控制请稍后再试',duration='1h',times=1) ``` ##### 或者 ``` import pywechat.WechatAuto as wechat wechat.auto_answer_call(broadcast_content='您好,我目前不在线我的PC微信正在由我的微信机器人控制请稍后再试',message='您好,我目前不在线我的PC微信正在由我的微信机器人控制请稍后再试',duration='1h',times=1) ``` ### 多任务使用示例 #### 注意,微信不支持多线程,只支持单线程多任务轮流执行,pywechat也支持单线程多任务轮流执行,在运行多个实例时尽量请将所有函数与方法内的close_wechat参数设为False(默认为True) #### 这样只需要打开一次微信,多个任务便可以共享资源,更加高效,否则,每个实例在运行时都会重启一次微信,较为低效。 #### 注意,不要对pywechat内函数或方法使用多线程,因为微信只能打开一个,多个线程同时操作一个微信界面,必然产生死锁,会导致界面卡死!
``` from pywechat.WechatAuto import Messages,Files Messages.send_messages_to_friend(friend='好友1',messages=['在测试','ok'],close_wechat=False) Files.send_files_to_friend(friend='文件传输助手',folder_path=r"E:\OneDrive\Desktop\测试专用",with_messages=True,messages_first=True,messages=['在测试文件消息一起发,你应该先看到这条消息,后看到文件'],close_wechat=True) ``` #### 效果演示: ![Alt text](https://github.com/Hello-Mr-Crab/pywechat/blob/main/pics/效果演示.gif)
##### 自动回复效果: ![Alt text](https://github.com/Hello-Mr-Crab/pywechat/blob/main/pics/Ai接入实例.png) ### 检查新消息示例
``` from pywechat import check_new_message print(check_new_message()) ``` ##### 检查新消息效果: ![Alt text](https://github.com/Hello-Mr-Crab/pywechat/blob/main/pics/check_new_message.gif) ##### 若你开启了语音自动转消息功能后,新消息中含有语音消息的话,可以将其转换结果一并记录。(1.8.8版本支持此功能) ## 注意: 👎👎请勿将pywechat用于任何非法商业活动,因此造成的一切后果由使用者自行承担! ###### 作者CSDN主页:https://blog.csdn.net/weixin_73953650?spm=1011.2415.3001.5343