网络编程
位置:首页>> 网络编程>> Python编程>> python使用wxpy实现微信消息防撤回脚本

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

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

标签:python,微信消息

本文实例为大家分享了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

0
投稿

猜你喜欢

  • Console 对象提供对浏览器控制台的接入(如:Firefox 的 Web Console)。不同浏览器上它的工作方式是不一样的,但这里会
  • ISNULL     使用指定的替换值替换   NULL。   &nb
  • async官方DOC介绍node安装npm install async --save使用var async = require('a
  • 本文分析了PHP7新特性之抽象语法树(AST)带来的变化。分享给大家供大家参考,具体如下:这里大部分内容参照 AST 的 RFC 文档而成:
  • 背景(background)在项目中经常会使用。这篇文章主要讲解的是实际项目中的5个实例。通过具体的分析来达到学习的目的。1,Li列表通过u
  • 给zblog添加上“运行代码”的功能,这是“密陀僧”修改z-blog源码,给z-bog增添的新功能。这个方法出来很久了,我现在才加上还不晚吧
  • #BEGIN CONFIG INFO#DESCR: 4GB RAM, 只使用InnoDB, ACID, 少量的连接, 队列负载大#TYPE:
  • CSS(叠层样式表)和XSL(可扩展样式语言)都可以定义XML文件的显示,这两种方式有哪些不同以及它们在使用中的具体方法,我们将在本文给予介
  • 在上一期中作者向诸位简要介绍了 ASP 脚本语言之一 VBScript 的一些基本常识,本期将继续给大家讲解 VBScript 的脚本编写方
  • 远程连接oracle只用PLSQLDeveloper客户端,不配置tnsnames.ora文件在PL/SQL中填写:1.UserName:用
  • 有时候很多朋友访问自己的asp或php等程序页面时出现一些错误,就是页面无法显示也没有详细的错误信息,就算iis中开启了显示详细的错误也不能
  • 1、动态sql, 即动态参数:在存储过程中,想要直接用表名变量做参数,动态执行sql,不能直接写<P>create proced
  • 下面是滚动条css代码参数介绍:scrollbar-3d-light-color 设置或检索滚动条亮边框颜色 scrollbar-highl
  • 很多人可能认为门户网站首页设计只是把一些导航、资讯内容和广告堆积起来摆放得好看就可以了,虽然这个观点也并不是完全错误的,确实门户网站首页是由
  • <%           &nbs
  • 引言 在前篇文章中(SQL查询入门(上篇),我对数据库查询的基本概念以及单表查询做了详细的解释,本篇文章中,主要说明SQL中的各种连接以及使
  • 清除浮动这个问题的提出,在现在来说应该算是一个非常古老的问题了,很多人对解决办法估计也能烂记于心了,但是我这个落后了不少的前端开发程序员,太
  • 我们在.NET程序的开发过程中,常常需要和用户进行信息交互,比如执行某项操作是否成功,“确定”还是“取消”,以及选择“确定”或“取消”后是否
  • 看lifesinger的《由Kimi找茬想到的》,我想到的:1、 我不同意将“合并付款”定调在“很多卖家都需要”。这个“很多”在卖家里面大概
  • 关于跨域这个话题,很早就答应过要分享,但是因为懒,一直拖着,直到D2上有人谈起了“完美跨域”。“跨域”应该已经算不上什么难题了,只是提起“完
手机版 网络编程 asp之家 www.aspxhome.com