优化内容

这篇不聊技术点,说一下优化后的Python机器人代码怎么使用,优化内容如下:

  1. 将hook库独立成一个库,发布到pypi,可使用pip安装
  2. 将微信相关的代码发布成另一个库,也可以pip安装
  3. git仓库统一,以后都在这个仓库更新,不再一篇文章一个仓库
  4. 开始建群,根据群里反馈增加功能和修复bug

使用教程

当前支持的微信版本

32位:

  • 3.9.8.12

64位:

  • 3.9.8.15

等这个系列教程结束再更新最新版本。其实hook库和主动调用都已经说完了,也可以等群友提pr来更新。

当前支持功能

  • 发送文本消息
  • 发送图片消息
  • hook微信日志输出
  • hook接收消息(下篇更新)
  • 防撤回(下篇更新)

准备环境

  1. 安装支持的版本微信 (下载链接: https://www.123pan.com/s/ihEKVv-XcWx.html 提取码: 5WLu)
  2. 安装32位或64位Python(取决于你安装的微信是32位还是64位),版本大于等于3.7
  3. pip install --upgrade wechat_pyrobot

后续如果要更新代码都需要执行一遍: pip install --upgrade wechat_pyrobot

使用

首先创建一个目录,例如robot_code,再创建一个main.py(名称随意)写入以下代码:

from py_process_hooker import inject_python_and_monitor_dir


if __name__ == "__main__":
    process_name = "WeChat.exe"
    open_console = True
    inject_python_and_monitor_dir(process_name, __file__, open_console=open_console)

启动并登录微信,执行这个main.py就会把Python注入到微信并且打开控制台,你也可以将open_console设置成False,就不会打开控制台,不过这样就不方便调试了

接着你在当前目录创建的任何代码保存后,都会被自动加载到微信并执行(注意创建的带代码文件名不能以数字开头)

发送消息

例如 创建一个sendmsg.py,写入以下代码后保存:

import time
from module import SendMsg


st = SendMsg()
st.send_text("filehelper", "测试消息!")
# 注意发送消息之间要间隔时间
time.sleep(1)
st.send_image("filehelper", r"D:\a.png")

第一个参数是wxid,获取方式后面再讲,或者下篇接收消息也能获取到好友的wxid,第二个参数是消息内容

发送消息时不要使用死循环,会阻塞Python进程,如果想定时发送消息,可以使用Python的定时器threading.Timer或者多线程threading.Thread

定时发消息

import time
from threading import Timer
from module import SendMsg


st = SendMsg()

def send_timer(n: int):
    global msg_timer
    t = time.strftime("%Y-%m-%d")
    msg_text = f"{t}: {n}"
    st.send_text("filehelper", msg_text)
    # 10秒后再执行一次
    msg_timer = Timer(10, send_timer, (n+1, ))
    msg_timer.start()
 
# 2秒后执行send_timer
msg_timer = Timer(2, send_timer, (1, ))
msg_timer.start()
# timer.cancel()#取消执行

如果想定点发消息,可以每隔一秒开启一个定时器,判断时间是否是符合要求,符合就发送,不符合就继续。

取消定时器(解释见下面的骚操作):

import sys

sendmsg_timer = sys.modules["sendmsg_timer"]
msg_timer = sendmsg_timer.msg_timer
msg_timer.cancel()

hook日志

例如创建一个hooklog.py,写入以下代码后保存:

from module import HookLog

hooker = HookLog()
hooker.hook() 

日志就会打印在控制台。hook不会阻塞进程,因为回调函数是在微信内部被调用,所以不需要使用多线程

骚操作

之前说了加载模块都会被保存在sys.modules这个字典里,而这个热加载就是以模块形式加载代码

所以你可以在新文件里引用之前文件的变量和方法,例如我新建一个unhooklog.py, 写入如下代码:

import sys

# 获取robot.py模块
robot = sys.modules["robot"]
# 获取robot模块中的hooker变量
hooker = robot.hooker
# 取消hook
hooker.unhook()

这在使用定时器和多线程时很有用,hook类已经被定义成了单例模式,不需要这样操作,你新建一个文件在实例化一个也是一样的效果

from module import HookLog

hooker = HookLog()
hooker.unhook() 

接收消息

待更新

防撤回

待更新