import itchat
from itchat.content import *
import os
import time
import xml.dom.minidom # 解析xml模块

这是保留撤回音讯的文件目录(如:图片、语音等),这里曾经写死了,大家能够自行批改

temp = '/Users/yourname/Documents/itchat' + '/' + '撤回的音讯'
if not os.path.exists(temp):

os.mkdir(temp)

itchat.auto_login(True) # 主动登录
dict = {} # 定义一个字典

这是一个装璜器,给上面的函数增加新性能

可能捕捉好友发送的音讯,并传递给函数参数msg

@itchat.msg_register([TEXT, PICTURE, FRIENDS, CARD, MAP, SHARING, RECORDING, ATTACHMENT, VIDEO]) # 文本,语音,图片
def resever_info(msg):

global dict    # 申明全局变量info = msg['Text']  # 取出音讯内容msgId = msg['MsgId']  # 取出音讯标识info_type = msg['Type']  # 取出音讯类型name = msg['FileName']  # 取出音讯文件名# 取出音讯发送者标识并从好友列表中检索fromUser = itchat.search_friends(userName=msg['FromUserName'])['NickName']ticks = msg['CreateTime']  # 获取信息发送的工夫time_local = time.localtime(ticks)dt = time.strftime("%Y-%m-%d %H:%M:%S", time_local)  # 格式化日期# 将音讯标识和音讯内容增加到字典# 每一条音讯的惟一标识作为键,音讯的具体信息作为值,也是一个字典dict[msgId] = {"info": info, "info_type": info_type, "name": name, "fromUser": fromUser, "dt": dt}

@itchat.msg_register(NOTE) # 监听系统提醒
def note_info(msg):

# 监听到好友撤回了一条音讯if '撤回了一条音讯' in msg['Text']:    # 获取零碎音讯中的Content结点值    content = msg['Content']    # Content值为xml,解析xml    doc = xml.dom.minidom.parseString(content)    # 取出msgid标签的值    result = doc.getElementsByTagName("msgid")    # 该msgId就是撤回的音讯标识,通过它能够在字典中找到撤回的音讯信息    msgId = result[0].childNodes[0].nodeValue    # 从字典中取出对应音讯标识的音讯类型    msg_type = dict[msgId]['info_type']    if msg_type == 'Recording':    # 撤回的音讯为语音        recording_info = dict[msgId]['info']  # 取出音讯标识对应的音讯内容        info_name = dict[msgId]['name'] # 取出音讯文件名        fromUser = dict[msgId]['fromUser'] # 取出发送者        dt = dict[msgId]['dt'] # 取出发送工夫        recording_info(temp + '/' + info_name) # 保留语音        # 拼接提醒音讯        send_msg = '【发送人:】' + fromUser + '\n' + '发送工夫:' + dt + '\n' + '撤回了一条语音'        itchat.send(send_msg, 'filehelper') # 将提醒音讯发送给文件助手        # 发送保留的语音        itchat.send_file(temp + '/' + info_name, 'filehelper')        del dict[msgId] # 删除字典中对应的音讯        print("保留语音")    elif msg_type == 'Text':        text_info = dict[msgId]['info'] # 取出音讯标识对应的音讯内容        fromUser = dict[msgId]['fromUser'] # 取出发送者        dt = dict[msgId]['dt'] # 取出发送工夫        # 拼接提醒音讯        send_msg = '【发送人:】' + fromUser + '\n' + '发送工夫:' + dt + '\n' + '撤回内容:' + text_info        # [农产品期货](https://www.gendan5.com/cf/af.html)将提醒音讯发送给文件助手        itchat.send(send_msg, 'filehelper')        del dict[msgId] # 删除字典中对应的音讯        print("保留文本")    elif msg_type == 'Picture':        picture_info = dict[msgId]['info'] # 取出音讯标识对应的音讯内容        fromUser = dict[msgId]['fromUser'] # 取出发送者        dt = dict[msgId]['dt'] # 取出发送工夫        info_name = dict[msgId]['name'] # 取出文件名        picture_info(temp + '/' + info_name) # 保留图片        # 拼接提醒音讯        send_msg = '【发送人:】' + fromUser + '\n' + '发送工夫:' + dt + '\n' + '撤回了一张图片'        itchat.send(send_msg, 'filehelper') # 将图片发送给文件助手        # 发送保留的语音        itchat.send_file(temp + '/' + info_name, 'filehelper')        del dict[msgId] # 删除字典中对应的音讯         print("保留图片")

itchat.run()