利用Python找回微信撤回信息
作者:python2021_ 发布时间:2022-11-21 22:34:03
标签:Python,找回,撤回,信息
一条撤回的微信消息,就像一个秘密,让你迫切地想去一探究竟;或如一个诱饵,瞬间勾起你强烈的兴趣。你想知道,那是怎样的一句话?是对方不慎讲出的真话,还是一句发错了对象的话?
总之,这个撤回的消息,让人顿生×××。这个时候,就是技术人员出马的时候了。
Python查看微信撤回消息参考代码:
import itchat
from itchat.content import *
import os
import time
import xml.dom.minidom # 解析xml模块
# 这是保存撤回消息的文件目录(如:图片、语音等)
temp = 'C:/Users/Administrator/Desktop/CrawlerDemo' + '/' + '撤回的消息'
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
# 将提示消息发送给文件助手
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()
来源:https://blog.csdn.net/python2021_/article/details/117961391


猜你喜欢
- 本文实例讲述了flask框架自定义过滤器。分享给大家供大家参考,具体如下:除了一些内置的join length safe等过滤器外, fla
- 学了一天pygame,用python和pygame写一个简单的挡板弹球游戏GitHub:EasyBaffleBallGame# -*- co
- inspect模块用于收集python对象的信息,可以获取类或函数的参数的信息,源码,解析堆栈,对对象进行类型检查等等,有几个好用的方法:D
- Microsoft? SQL Server? 2000 提供了两种主要机制来强制业务规则和数据完整性:约束和触发器。触发器是一种特殊类型的存
- 该章节为 Python自动化办公篇 的最后一章,通过定时任务发送邮件的方式学习定时模块的使用 --> schedule 。(该章内容篇
- 基本映射映射使用在根据不同URLs请求来产生相对应的返回内容.Bottle使用route() 修饰器来实现映射.from bottle im
- 现在做的一个小项目需要用到python的相关知识,但是因为太久没用一些东西都忘掉了,因此在本篇博客中记录一下python的函数和类的基础知识
- 目录前言typeof是否能正确判断类型?instanceof是否能正确判断类型?Object.prototype.toString.call
- 前言:什么是分布式事务?银行跨行转账业务是一个典型分布式事务场景,假设A需要跨行转账给B,那么就涉及两个银行的数据,无法通过一个数据库的本地
- 前言本文从单元测试实践角度出发,提升对代码质量的意识。本文内容主要包括:单元测试、Mock测试、基准测试。测试测试可以提高代码的质量、减少事
- Go 程序运行时,有些场景下会导致进程进入某个“高点”,然后就再也下不来了。比如,多年前曹大写过的一
- blob对象介绍一个 Blob对象表示一个不可变的, 原始数据的类似文件对象。Blob表示的数据不一定是一个JavaScript原生格式 b
- 今天用实验室的pycharm运行程序的时候发现出现了已安装的模块无法导入的情况,但实际上这个模块我已经在notebook中使用多次了,所以不
- 记录使用pytorch构建网络模型过程遇到的点1. 网络模型构建中的问题1.1 输入变量是Tensor张量各个模块和网络模型的输入,一定要是
- 本文实例为大家分享了小程序实现横向滑动日历效果的具体代码,供大家参考,具体内容如下<scroll-view class="s
- 在 ASP 的内建对象中除了用于发送、接收和处理数据的对象外,还有一些非常实用的代表 Active Server 应用程序和单个
- 如下所示:#-*- encoding:utf-8 -*-from tkinter import *root = Tk()def create
- 引用Nmap库实现扫描功能,本节课比较简单一看就会。编写环境:Python2.x编写:首先安装Nmap程序,并添加环境变量pip insta
- 有时候,预先不知道函数需要接受多少个实参,好在Python允许函数从调用语句中调用语句中收集任意数量的实参。在参数前加上*号。来看一个制作披
- 见下表:序号列类型需要的存储量1TINYINT1 字节2SMALLINT2 个字节3MEDIUMINT3 个字节4INT4 个字节5INTE