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

相关文章
|
8天前
|
测试技术 Python
探索Python中的装饰器:简化代码,增强功能
在Python的世界中,装饰器是那些能够为我们的代码增添魔力的小精灵。它们不仅让代码看起来更加优雅,还能在不改变原有函数定义的情况下,增加额外的功能。本文将通过生动的例子和易于理解的语言,带你领略装饰器的奥秘,从基础概念到实际应用,一起开启Python装饰器的奇妙旅程。
26 11
|
23天前
|
缓存 监控 测试技术
Python中的装饰器:功能扩展与代码复用的利器###
本文深入探讨了Python中装饰器的概念、实现机制及其在实际开发中的应用价值。通过生动的实例和详尽的解释,文章展示了装饰器如何增强函数功能、提升代码可读性和维护性,并鼓励读者在项目中灵活运用这一强大的语言特性。 ###
|
26天前
|
缓存 开发者 Python
探索Python中的装饰器:简化代码,增强功能
【10月更文挑战第35天】装饰器在Python中是一种强大的工具,它允许开发者在不修改原有函数代码的情况下增加额外的功能。本文旨在通过简明的语言和实际的编码示例,带领读者理解装饰器的概念、用法及其在实际编程场景中的应用,从而提升代码的可读性和复用性。
|
27天前
|
设计模式 缓存 监控
Python中的装饰器:代码的魔法增强剂
在Python编程中,装饰器是一种强大而灵活的工具,它允许程序员在不修改函数或方法源代码的情况下增加额外的功能。本文将探讨装饰器的定义、工作原理以及如何通过自定义和标准库中的装饰器来优化代码结构和提高开发效率。通过实例演示,我们将深入了解装饰器的应用,包括日志记录、性能测量、事务处理等常见场景。此外,我们还将讨论装饰器的高级用法,如带参数的装饰器和类装饰器,为读者提供全面的装饰器使用指南。
|
22天前
|
Python
探索Python中的装饰器:简化代码,提升效率
【10月更文挑战第39天】在编程的世界中,我们总是在寻找使代码更简洁、更高效的方法。Python的装饰器提供了一种强大的工具,能够让我们做到这一点。本文将深入探讨装饰器的基本概念,展示如何通过它们来增强函数的功能,同时保持代码的整洁性。我们将从基础开始,逐步深入到装饰器的高级用法,让你了解如何利用这一特性来优化你的Python代码。准备好让你的代码变得更加优雅和强大了吗?让我们开始吧!
22 1
|
23天前
|
存储 缓存 监控
掌握Python装饰器:提升代码复用性与可读性的利器
在本文中,我们将深入探讨Python装饰器的概念、工作原理以及如何有效地应用它们来增强代码的可读性和复用性。不同于传统的函数调用,装饰器提供了一种优雅的方式来修改或扩展函数的行为,而无需直接修改原始函数代码。通过实际示例和应用场景分析,本文旨在帮助读者理解装饰器的实用性,并鼓励在日常编程实践中灵活运用这一强大特性。
|
25天前
|
机器学习/深度学习 数据采集 人工智能
探索机器学习:从理论到Python代码实践
【10月更文挑战第36天】本文将深入浅出地介绍机器学习的基本概念、主要算法及其在Python中的实现。我们将通过实际案例,展示如何使用scikit-learn库进行数据预处理、模型选择和参数调优。无论你是初学者还是有一定基础的开发者,都能从中获得启发和实践指导。
41 2
|
2月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
616 7
|
2月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
714 1
|
2月前
|
小程序 前端开发 测试技术
微信小程序的开发完整流程是什么?
微信小程序的开发完整流程是什么?
126 7