撤回的微信消息真的看不到?78行Python代码帮你看穿一切!

简介: 撤回的微信消息真的看不到?78行Python代码帮你看穿一切!

全栈开发者资料大全 小编从java开始带大家学习,每天早上7点定时发推文,大家养成好习惯,记得把公众号置顶,知识点由浅入深,相信跟着小编步伐坚持下去的将来一定精通全栈,行业大佬!有问题私聊小编vx:15222301178!


导读:Python曾经对我说:"时日不多,赶紧用Python"。于是看到了一个基于python的微信开源库:itchat,玩了一天,做了一个程序,把私聊撤回的信息可以收集起来并发送到个人微信的文件传输助手,包括:

(1) who :谁发送的

(2) when :什么时候发送的消息

(3) what:什么信息

(4) which:哪一类信息,包括:文本、图片、语音、视频、分享、位置、附件

...

01 代码实现

# -*-encoding:utf-8-*-
import os
import re
import shutil
import time
import itchat
from itchat.content import *
# 说明:可以撤回的有文本文字、语音、视频、图片、位置、名片、分享、附件
# {msg_id:(msg_from,msg_to,msg_time,msg_time_rec,msg_type,msg_content,msg_share_url)}
msg_dict = {}
# 文件存储临时目录
rev_tmp_dir = "/home/alic/RevDir/"
if not os.path.exists(rev_tmp_dir): os.mkdir(rev_tmp_dir)
# 表情有一个问题 | 接受信息和接受note的msg_id不一致 巧合解决方案
face_bug = None
# 将接收到的消息存放在字典中,当接收到新消息时对字典中超时的消息进行清理 | 不接受不具有撤回功能的信息
# [TEXT, PICTURE, MAP, CARD, SHARING, RECORDING, ATTACHMENT, VIDEO, FRIENDS, NOTE]
@itchat.msg_register([TEXT, PICTURE, MAP, CARD, SHARING, RECORDING, ATTACHMENT, VIDEO])
def handler_receive_msg(msg):
   global face_bug
   # 获取的是本地时间戳并格式化本地时间戳 e: 2017-04-21 21:30:08
   msg_time_rec = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
   # 消息ID
   msg_id = msg['MsgId']
   # 消息时间
   msg_time = msg['CreateTime']
   # 消息发送人昵称 | 这里也可以使用RemarkName备注 但是自己或者没有备注的人为None
   msg_from = (itchat.search_friends(userName=msg['FromUserName']))["NickName"]
   # 消息内容
   msg_content = None
   # 分享的链接
   msg_share_url = None
   if msg['Type'] == 'Text' 
           or msg['Type'] == 'Friends':
       msg_content = msg['Text']
   elif msg['Type'] == 'Recording' 
           or msg['Type'] == 'Attachment' 
           or msg['Type'] == 'Video' 
           or msg['Type'] == 'Picture':
       msg_content = r"" + msg['FileName']
       # 保存文件
       msg['Text'](rev_tmp_dir + msg['FileName'])
   elif msg['Type'] == 'Card':
       msg_content = msg['RecommendInfo']['NickName'] + r" 的名片"
   elif msg['Type'] == 'Map':
       x, y, location = re.search(
           "<location x="(.*?)" y="(.*?)".*label="(.*?)".*", msg['OriContent']).group(1, 2, 3)
       if location is None:
           msg_content = r"纬度->" + x.__str__() + " 经度->" + y.__str__()
       else:
           msg_content = r"" + location
   elif msg['Type'] == 'Sharing':
       msg_content = msg['Text']
       msg_share_url = msg['Url']
   face_bug = msg_content
   # 更新字典
   msg_dict.update(
       {
           msg_id: {
               "msg_from": msg_from, "msg_time": msg_time, "msg_time_rec": msg_time_rec,
               "msg_type": msg["Type"],
               "msg_content": msg_content, "msg_share_url": msg_share_url
           }
       }
   )
# 收到note通知类消息,判断是不是撤回并进行相应操作
@itchat.msg_register([NOTE])
def send_msg_helper(msg):
   global face_bug
   if re.search(r"<![CDATA[.*撤回了一条消息]]>", msg['Content']) is not None:
       # 获取消息的id
       old_msg_id = re.search("<msgid>(.*?)</msgid>", msg['Content']).group(1)
       old_msg = msg_dict.get(old_msg_id, {})
       if len(old_msg_id) < 11:
           itchat.send_file(rev_tmp_dir + face_bug, toUserName='filehelper')
           os.remove(rev_tmp_dir + face_bug)
       else:
           msg_body = "告诉你一个秘密~" + " " 
                      + old_msg.get('msg_from') + " 撤回了 " + old_msg.get("msg_type") + " 消息" + " " 
                      + old_msg.get('msg_time_rec') + " " 
                      + "撤回了什么 ⇣" + " " 
                      + r"" + old_msg.get('msg_content')
           # 如果是分享存在链接
           if old_msg['msg_type'] == "Sharing": msg_body += " 就是这个链接➣ " + old_msg.get('msg_share_url')
           # 将撤回消息发送到文件助手
           itchat.send(msg_body, toUserName='filehelper')
           # 有文件的话也要将文件发送回去
           if old_msg["msg_type"] == "Picture" 
                   or old_msg["msg_type"] == "Recording" 
                   or old_msg["msg_type"] == "Video" 
                   or old_msg["msg_type"] == "Attachment":
               file = '@fil@%s' % (rev_tmp_dir + old_msg['msg_content'])
               itchat.send(msg=file, toUserName='filehelper')
               os.remove(rev_tmp_dir + old_msg['msg_content'])
           # 删除字典旧消息
           msg_dict.pop(old_msg_id)
if __name__ == '__main__':
   itchat.auto_login(hotReload=True,enableCmdQR=2)
   itchat.run()

该程序可以直接在终端运行,在终端扫码成功够即可登录成功,同时也可以打包在window系统运行(注意修改一下路径,推荐使用相对路径)。

➜  ~ python wx.py
Getting uuid of QR code.
Downloading QR code.
Please scan the QR code to log in.
Please press confirm on your phone.
Loading the contact, this may take a little while.
�[3;J
Login successfully as AlicFeng
Start auto replying.

02 效果图

03 itchat

上面都是编程逻辑的小事,我还是记录一下itchat微信这个开源库。

1. 简介

itchat是一个开源的微信个人号接口,使用python调用微信变得非常简单。简单是用itchat代码即可构建一个基于微信的即时通讯,更不错的体现在于方便扩展个人微信的在其他平台的更多通讯功能。

2. 安装

pip3 install itchat


3. itchat - Helloworld

仅仅三行代码发送一条信息给文件传输助手。

import itchat
itchat.auto_login(hotReload=True)
itchat.send('Hello AlicFeng', toUserName='filehelper')

4. 查看客户端

全栈开发者社区

IDquanzhankaifazhe

 全栈开发者社区 由985/211高校软件工程爱好者联合创办,创办以来我们以“相互学习,相互帮助,追求共同进步”为服务宗旨,免费分享学习资源,分享学习路线,解决学习难题,每天定时推送原创文章,现已有数万粉丝,只有你想不到的困惑,没有我们解决不了的问题。关注全栈开发者社区,小编带你搞事情!

相关文章
|
1月前
|
开发框架 数据建模 中间件
Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器是那些静悄悄的幕后英雄。它们不张扬,却能默默地为函数或类增添强大的功能。本文将带你了解装饰器的魅力所在,从基础概念到实际应用,我们一步步揭开装饰器的神秘面纱。准备好了吗?让我们开始这段简洁而富有启发性的旅程吧!
38 6
|
11天前
|
Python
自动化微信朋友圈:Python脚本实现自动发布动态
本文介绍如何使用Python脚本自动化发布微信朋友圈动态,节省手动输入的时间。主要依赖`pyautogui`、`time`、`pyperclip`等库,通过模拟鼠标和键盘操作实现自动发布。代码涵盖打开微信、定位朋友圈、准备输入框、模拟打字等功能。虽然该方法能提高效率,但需注意可能违反微信使用条款,存在风险。定期更新脚本以适应微信界面变化也很重要。
117 60
|
8天前
|
Python
课程设计项目之基于Python实现围棋游戏代码
游戏进去默认为九路玩法,当然也可以选择十三路或是十九路玩法 使用pycharam打开项目,pip安装模块并引用,然后运行即可, 代码每行都有详细的注释,可以做课程设计或者毕业设计项目参考
51 33
|
9天前
|
JavaScript API C#
【Azure Developer】Python代码调用Graph API将外部用户添加到组,结果无效,也无错误信息
根据Graph API文档,在单个请求中将多个成员添加到组时,Python代码示例中的`members@odata.bind`被错误写为`members@odata_bind`,导致用户未成功添加。
36 10
|
29天前
|
数据可视化 Python
以下是一些常用的图表类型及其Python代码示例,使用Matplotlib和Seaborn库。
通过这些思维导图和分析说明表,您可以更直观地理解和选择适合的数据可视化图表类型,帮助更有效地展示和分析数据。
67 8
|
1月前
|
API Python
【Azure Developer】分享一段Python代码调用Graph API创建用户的示例
分享一段Python代码调用Graph API创建用户的示例
55 11
|
1月前
|
Python
探索Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器就像是给函数穿上了一件神奇的外套,让它们拥有了超能力。本文将通过浅显易懂的语言和生动的比喻,带你了解装饰器的基本概念、使用方法以及它们如何让你的代码变得更加简洁高效。让我们一起揭开装饰器的神秘面纱,看看它是如何在不改变函数核心逻辑的情况下,为函数增添新功能的吧!
|
1月前
|
程序员 测试技术 数据安全/隐私保护
深入理解Python装饰器:提升代码重用与可读性
本文旨在为中高级Python开发者提供一份关于装饰器的深度解析。通过探讨装饰器的基本原理、类型以及在实际项目中的应用案例,帮助读者更好地理解并运用这一强大的语言特性。不同于常规摘要,本文将以一个实际的软件开发场景引入,逐步揭示装饰器如何优化代码结构,提高开发效率和代码质量。
51 6
|
4月前
|
人工智能 数据挖掘 数据处理
揭秘Python编程之美:从基础到进阶的代码实践之旅
【9月更文挑战第14天】本文将带领读者深入探索Python编程语言的魅力所在。通过简明扼要的示例,我们将揭示Python如何简化复杂问题,提升编程效率。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开一扇通往高效编码世界的大门。让我们开始这段充满智慧和乐趣的Python编程之旅吧!
|
2月前
|
机器学习/深度学习 数据采集 人工智能
探索机器学习:从理论到Python代码实践
【10月更文挑战第36天】本文将深入浅出地介绍机器学习的基本概念、主要算法及其在Python中的实现。我们将通过实际案例,展示如何使用scikit-learn库进行数据预处理、模型选择和参数调优。无论你是初学者还是有一定基础的开发者,都能从中获得启发和实践指导。
61 2
下一篇
开通oss服务