python实现微信防撤回神器
作者:nmyphp 发布时间:2022-03-14 14:22:04
标签:python,微信,撤回
本文实例为大家分享了python实现微信防撤回神器的具体代码,供大家参考,具体内容如下
手写辛苦,希望给赞
#!/usr/local/bin/python3
# coding=utf-8
import os
import re
import time
import _thread
import itchat
from itchat.content import *
# 可以撤回的消息格式:文本、语音、视频、图片、位置、名片、分享、附件
# 存储收到的消息
# 格式:{msg_id:{msg_from,msg_to,msg_time,msg_time_rec,msg_tye,msg_content,msg_share_url}}
msg_dict = {}
# 存储消息中文件的临时目录,程序启动时,先清空
rev_tmp_dir = "/Users/chenlong/d1/wechat/rev/"
if not os.path.exists(rev_tmp_dir):
os.mkdir(rev_tmp_dir)
else:
for f in os.listdir(rev_tmp_dir):
path = os.path.join(rev_tmp_dir, f)
if os.path.isfile(path):
os.remove(path)
# 表情有一个问题:消息和撤回提示的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, FRIENDS, NOTE],
isFriendChat=True, isGroupChat=True, isMpChat=True)
def handler_reveive_msg(msg):
global face_bug
msg_time_rev = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
msg_id = msg['MsgId']
msg_time = msg['CreateTime']
msg_share_url = None
group_name = None
# 获取发送人
if 'ActualNickName' in msg:
sender_info = set_sender_group_chat(msg)
msg_from = sender_info['msg_from']
group_name = sender_info['group_name']
else:
msg_from = (itchat.search_friends(userName=msg['FromUserName']))['RemarkName'] # 优先使用备注
if msg_from is None:
msg_from = msg['FromUserName']
# 获取消息内容
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 + " 经度->" + y
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_rev": msg_time_rev,
"msg_type": msg['Type'],
"msg_content": msg_content,
"msg_share_url": msg_share_url,
"group_name": group_name
}
})
# 遍历本地消息字典,清除2分钟之前的消息,并删除缓存的消息对应的文件
def clear_timeout_msg():
need_del_msg_ids = []
for m in msg_dict:
msg_time = msg_dict[m]['msg_time']
if int(time.time()) - msg_time > 120:
need_del_msg_ids.append(m)
if len(need_del_msg_ids) > 0:
for i in need_del_msg_ids:
old_msg = msg_dict.get(i)
if old_msg['msg_type'] == PICTURE or old_msg['msg_type'] == RECORDING or old_msg['msg_type'] == VIDEO \
or old_msg['msg_type'] == ATTACHMENT:
os.remove(rev_tmp_dir + old_msg['msg_content'])
msg_dict.pop(i)
# 设置发送人,当消息是群消息的时候
def set_sender_group_chat(msg):
msg_from = msg['ActualNickName']
# 查找用户备注名称
friends = itchat.get_friends(update=True)
from_user = msg['ActualUserName']
for f in friends:
if from_user == f['UserName']:
msg_from = f['RemarkName'] or f['NickName']
break
groups = itchat.get_chatrooms(update=True)
for g in groups:
if msg['FromUserName'] == g['UserName']:
group_name = g['NickName']
break
return {'msg_from': msg_from, 'group_name': group_name}
# 监听通知,判断是撤回通知,则将消息发给文件助手
@itchat.msg_register([NOTE], isFriendChat=True, isGroupChat=True, isMpChat=True)
def send_msg_helper(msg):
global face_bug
if re.search(r"\<\!\[CDATA\[.*撤回了一条消息\]\]\>", msg['Content']) is not None:
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') \
+ "消息\n" \
+ old_msg.get('msg_time_rev') + "\n" \
+ old_msg.get('msg_content')
if old_msg.get('group_name') is not None:
msg_body = old_msg.get('group_name') + ">" + msg_body
if old_msg['msg_type'] == "Sharing":
msg_body += "\n" + 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()
# 子线程清除超时消息
_thread.start_new_thread(clear_timeout_msg)
来源:https://blog.csdn.net/nmyphp/article/details/84582914
0
投稿
猜你喜欢
- 当你在IE中点击一个Realplayer连接时,系统会自动启动Realplayer软件,不仅占用系统内存,而且在上网时Realplayer容
- 概述从前面的对Python基础知识方法介绍中,我们几乎是围绕Python内置方法进行探索实践,比如字符串、列表、字典等数据结构的内置方法,和
- 经常在网站上看到诸如www.abc.com/?news或者www.abc.com/?id=123这样的网址,一开始觉得很神秘,其实现在看多了
- 本文实例讲述了python计算方程式根的方法。分享给大家供大家参考。具体实现方法如下:''' roots = pol
- 引言提到 numpy 的数组操作,我们就不得不说到 np.concatenate() 函数,concatenate 一词在英文中是级联的意思
- 背景客户最近有这样的需求,想通过统计Oracle数据库活跃会话数,并记录在案,利用比对历史的活跃会话的方式,实现对系统整体用户并发量有大概的
- 单目标跟踪:直接调用opencv中封装的tracker即可。#!/usr/bin/env python3# -*- coding: utf-
- 大部分服务器管理员知道MySQL数据库管理系统(RDBMS)是高度灵活的软件块,带有范围广阔的启动选项,可以用来修改相关行为。然而,大部分人
- 前言Pandas是Python下一个开源数据分析的库,它提供的数据结构DataFrame极大的简化了数据分析过程中一些繁琐操作。1. 基本使
- 首先这是VGG的结构图,VGG11则是红色框里的结构,共分五个block,如红框中的VGG11第一个block就是一个conv3-64卷积层
- HTTP状态码 摘要说明成功2××  
- 在使用数据库的时候,难免要在使用过程中进行删除的操作,如果是使用int类型的字段,令其自增长,这是个最简单的办法,但是后果会有些不是你想要的
- 对于一个net开发这爬虫真真的以前没有写过。这段时间开始学习python爬虫,今天周末无聊写了一段代码爬取上海租房图片,其实很简短就是利用爬
- transforms按住Ctrl查看transforms的源码可以知道,transforms就是一个python文件,里面定义了很多类,每一
- 使用SQL Server事件探查器工具,你可用一个捕获到的跟踪来收集有关服务器的重要信息。与索引优化向导(Index Tuning Wiza
- 从MySQL 5.0 开始,支持了一个全新的SQL句法:PREPARE stmt_name FROM preparable_stmt;EXE
- 本文实例讲述了python使用webbrowser浏览指定url的方法。分享给大家供大家参考。具体如下:这段代码提示用户输入关键词,通过we
- 需求如下: 1.模板页右边包含了一个登陆div,想让没登陆的时候这个div显示,登陆后该div隐藏 2.显示一个欢迎用户的div,主要是想通
- 一、数组的创建方式一var a = new Array(); a[0]="wo"
- 通过设置全局随机种子使得每次的训练结果相同可以复现def seed_torch(seed=2018): rando