关于python:如何用Python记录微信撤回的消息

3次阅读

共计 2428 个字符,预计需要花费 7 分钟才能阅读完成。

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()

正文完
 0