python使用wxpy实现微信消息防撤回脚本

作者:babaili_ 时间:2023-08-22 21:21:58 

本文实例为大家分享了python实现微信消息防撤回的具体代码,供大家参考,具体内容如下

使用了sqlite3保存数据,当有人撤回消息时取出数据发送到文件传输助手。

文件的话会先保存到本地,语音会以文件的方式发送。

wxpy 和 itchat很久没更新了,有些功能没法用了,web微信也不知道什么时候会凉。

帮助信息在注释里。


# -*- coding: utf-8 -*-

# 使用sqlite3保存message,当有人撤回消息时在数据库中通过ID检索该消息是否存在,如果存在则将撤回的消息发送到文件助手里。
# 目前只支持 text picture map sharing recording video attachment 类型的消息。

import wxpy
import sqlite3
import os
import re

# 准备工作
# 创建attachment目录用于存储 图像、地图/位置、分享、语音、视频、文件
if not os.path.isdir('attachment'):
 os.mkdir('attachment')
attachment_path = os.path.join(os.getcwd(), 'attachment')
bot = wxpy.Bot()
# 用于获取msg ID
pattern = re.compile(r'\d{19}')
# 测试wxpy能否正常工作
myself = bot.friends()[0]
myself.send('Hello?')

# 创建数据库和message表
try:
 conn = sqlite3.connect('wxpy.db')
 cursor = conn.cursor()
 # cursor.execute('DROP TABLE MESSAGES')
 cursor.execute("""CREATE TABLE IF NOT EXISTS MESSAGES (id INTEGER PRIMARY KEY AUTOINCREMENT,
          msg_id INTEGER NOT NULL,
          msg_text TEXT,
          create_time DATE NOT NULL,
          revoke_time DATE,
          attachment_path TEXT,
          msg_sender TEXT NOT NULL,
          msg_type TEXT NOT NULL,
          msg_url TEXT,
          msg_raw_data TEXT NOT NULL)""")
 # print('establish successfully')
finally:
 conn.commit()
 cursor.close()
 conn.close()

# 注册所有消息,在程序运行期间将插入所有支持的信息
@bot.register()
def store_data(msg):
 # print(msg.raw)
 # 如果消息是支持的类型就将数据插入数据库
 if msg.type in [wxpy.TEXT, wxpy.RECORDING, wxpy.PICTURE, wxpy.ATTACHMENT, wxpy.VIDEO, wxpy.SHARING, wxpy.MAP]:
   insert_data(msg)
 # 撤回的消息类型是note
 elif msg.type == wxpy.NOTE:
   send_revoke(msg)

# 插入数据
def insert_data(msg):
 try:
   conn = sqlite3.connect('wxpy.db')
   cursor = conn.cursor()
   if msg.type == wxpy.TEXT:
     cursor.execute("INSERT INTO MESSAGES (msg_id, msg_text, create_time, msg_sender, msg_type, msg_raw_data)\
             values (?, ?, ?, ?, ?, ?)", (msg.id, msg.text, msg.create_time, str(msg.sender)[9:-1],
                            msg.type, str(msg.raw)))

# 将录音/图像/文件/视频下载到本地,插入保存路径。
   elif msg.type in [wxpy.RECORDING, wxpy.PICTURE, wxpy.ATTACHMENT, wxpy.VIDEO]:
     save_path = os.path.join(attachment_path, msg.file_name)
     msg.get_file(save_path)
     cursor.execute('INSERT INTO MESSAGES (msg_id, create_time, attachment_path, msg_sender, msg_type,\
             msg_raw_data) values (?, ?, ?, ?, ?, ?)',
             (msg.id, msg.create_time, save_path, str(msg.sender)[9:-1], msg.type, str(msg.raw)))

# 插入分享/位置链接
   elif msg.type in [wxpy.SHARING, wxpy.MAP]:
     cursor.execute('INSERT INTO MESSAGES (msg_id, msg_text, create_time, msg_sender, msg_type, msg_url,\
             msg_raw_data) values (?, ?, ?, ?, ?, ?, ?)',
             (msg.id, msg.text, msg.create_time, str(msg.sender)[9:-1], msg.type, str(msg.url), str(msg.raw)))
   # print('insert data successfully')

finally:
   conn.commit()
   cursor.close()
   conn.close()

# 在数据库中检索消息是否存在,如果存在则将被撤回的消息发送到文件传输助手。
def send_revoke(message):
 msg_id = pattern.search(message.raw['Content']).group()
 try:
   conn = sqlite3.connect('wxpy.db')
   cursor = conn.cursor()
   cursor.execute('INSERT INTO MESSAGES (msg_id, create_time, msg_sender, msg_type, msg_raw_data)\
           values (?, ?, ?, ?, ?)',
           (message.id, message.create_time, str(message.sender)[9:-1], message.type, str(message.raw)))
   msg_data = cursor.execute('SELECT * FROM MESSAGES WHERE msg_id=?', (msg_id, )).fetchall()
   # print('take out data successfully')
 finally:
   conn.commit()
   cursor.close()
   conn.close()
 if msg_data[0][7] == 'Text':
   msg_info = '告诉你一个秘密 {} 在 {} 撤回了文本\n{}'.format(msg_data[0][6], msg_data[0][3], msg_data[0][2])
   bot.file_helper.send(msg_info)
 else:
   send_revoke_nontext(msg_data)

# 非文本信息发送
def send_revoke_nontext(msg_data):
 if msg_data[0][7] == 'Picture':
   if msg_data[0][5][-4:] == '.gif':
     # 现在wxpy & itchat发不了GIF了
     bot.file_helper('很抱歉,暂时不支持表情(gif)的撤回重发。')
   else:
     msg_info = '告诉你一个秘密 {} 在 {} 撤回了图像'.format(msg_data[0][6], msg_data[0][3])
     bot.file_helper.send(msg_info)
     bot.file_helper.send_image(msg_data[0][5])
 elif msg_data[0][7] == 'Recording':
   msg_info = '告诉你一个秘密 {} 在 {} 撤回了语音'.format(msg_data[0][6], msg_data[0][3])
   bot.file_helper.send(msg_info)
   bot.file_helper.send_file(msg_data[0][5])
 elif msg_data[0][7] == 'Attachment':
   msg_info = '告诉你一个秘密 {} 在 {} 撤回了文件'.format(msg_data[0][6], msg_data[0][3])
   bot.file_helper.send(msg_info)
   bot.file_helper.send_file(msg_data[0][5])
 elif msg_data[0][7] == 'Video':
   msg_info = '告诉你一个秘密 {} 在 {} 撤回了视频'.format(msg_data[0][6], msg_data[0][3])
   bot.file_helper.send(msg_info)
   bot.file_helper.send_video(msg_data[0][5])
 elif msg_data[0][7] == 'Sharing':
   msg_info = '告诉你一个秘密 {} 在 {} 撤回了分享\n{}\n{}'.format(msg_data[0][6], msg_data[0][3], msg_data[0][2],\
                            msg_data[0][8])
   bot.file_helper.send(msg_info)
 elif msg_data[0][7] == 'Map':
   msg_info = '告诉你一个秘密 {} 在 {} 撤回了位置\n{}\n{}'.format(msg_data[0][6], msg_data[0][3], msg_data[0][2],\
                            msg_data[0][8])
   bot.file_helper.send(msg_info)

wxpy.embed()

来源:https://blog.csdn.net/babaili_/article/details/85947411

标签:python,微信消息
0
投稿

猜你喜欢

  • HTML和SEO基础知识:H标签全透视

    2010-09-21 16:45:00
  • 树型结构在ASP中的简单解决

    2007-10-07 12:52:00
  • Oracle备库宕机启动的完美解决方案

    2023-07-20 05:28:34
  • CSS的优先级与特殊性

    2008-06-24 11:36:00
  • MS SQL 查询数据在数据库中所在行

    2009-04-26 19:36:00
  • 基于insertBefore制作简单的循环插空效果

    2023-08-17 22:34:17
  • Ajax编程之旅第一站:HTTP请求

    2008-08-07 12:55:00
  • SQL学习笔记三 select语句的各种形式小结

    2011-09-30 11:09:31
  • HTML 标签是否匹配检测代码

    2010-03-17 20:50:00
  • asp如何刪除客户端的Cookies?

    2010-05-18 18:25:00
  • SQL Server与Oracle数据库在查询优化上的差异

    2009-02-18 14:28:00
  • 关于对Java正则表达式"\\\\"的理解

    2023-06-24 07:23:02
  • 在HTML中,常见的URL有多种表示方式:

    2009-07-28 12:18:00
  • SQLServer中用T—SQL命令查询一个数据库中有哪些表的sql语句

    2012-07-11 15:28:50
  • MySQL数据库对dvbbs.php全文搜索的完全分析

    2010-06-11 13:25:00
  • Persits AspJpeg组件图片水印\\缩略图\\图片合并\\图片切割\\实例教程

    2008-12-14 10:36:00
  • PHP基于phpqrcode类生成二维码的方法详解

    2023-06-12 17:20:38
  • Sql Server、Oracle以及Access数据库 判断字段是否为空的办法 (From calmzeal's code life)

    2011-02-24 19:44:00
  • 三种禁用FileSystemObject组件的方法

    2007-09-23 15:52:00
  • 详解AJAX核心 —— XMLHttpRequest 对象

    2010-03-31 14:49:00
  • asp之家 网络编程 m.aspxhome.com