应用背景

xxx撤回了一条消息 有时遇到这种情况是不是感觉被吊着胃口,对方到底撤回了什么消息呢?好想知道啊;
还有时候会加到一些营销号甚至是骗子,这时使用机器人模式自动回复他岂不快哉,或者可以让朋友像调戏siri那样调戏自己;

本文目的

网上有很多使用python itchat实现 防消息撤回自动聊天机器人 的资料。虽然很简单,但大都不够直白或残缺不全。对于没有没有编程经验的人来说,想自己动手模仿还是有些困难的。所以,本文主要针对非IT从业者,手把手的教会他们怎么用起来那些听起来"高大上"的功能。

防消息撤回(小白看这一步就够了)

该部分内容都基于Window环境,毕竟大部分人都使用该系统。

  1. 下载网盘中的这三个文件到本地
    百度网盘:https://pan.baidu.com/s/1GlbRWnMwLlZnCBhmiVTLOg
    提取码:8367
  2. 安装python-3.7.2-amd64.exe



  3. 测试python-3.7.2-amd64.exe是否安装成功(非必要,可跳过
  4. 安装完成后,双击执行start.bat就OK了。(保持start.batlittleJoy.py在同一目录下)
  5. 使用手机微信扫描二维码,授权登陆即可。
  6. 完成以上步骤,他人撤回的消息就会自动转发到你微信上的文件助手

若对自动回复功能以及智能机器人回复功能感兴趣的朋友。可以继续阅读下面的内容,下面的内容会涉及到部分代码的更改。

消息回复

对于没有编码经验的人来说,要清楚怎么使用机器人智能回复,是很困难的。我要说清楚,可能要讲一部甄嬛传啦。所以,下面就直接粗暴的上了代码,有兴趣可以自己慢慢研究;
对于IT从业者来说,只需提醒你,要更改图灵网站访问API的授权码。至于智能消息回复模式的开启策略逻辑(都是一些简单的ifelse),可以自行阅读handle_msg_reply(msg)方法,你可以按需要自己更改;

代码如下:

# coding:utf-8
import importlib
import itchat
from itchat.content import TEXT
from itchat.content import *
import requests, json
import sys
import time
import reimportlib.reload(sys)
#sys.setdefaultencoding('utf8')
import osmsg_information = {}
face_bug=None  #针对表情包的内容auto_reply = False
robot_reply = False
peer_list = []
peer_name_list = []@itchat.msg_register([TEXT, PICTURE, FRIENDS, CARD, MAP, SHARING, RECORDING, ATTACHMENT, VIDEO],isFriendChat=True, isMpChat=True)
def handle_receive_msg(msg):global face_bughandle_msg_reply(msg) #信息自动回复包含智能机器人回复msg_time_rec = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())   #接受消息的时间#msg_from = itchat.search_friends(userName=msg['FromUserName'])['NickName']   #在好友列表中查询发送信息的好友昵称friend = itchat.search_friends(userName=msg['FromUserName'])if friend is None:msg_from = 'Unknown Name'#print (u'信息发送人不在好友列表中!')else:msg_from = friend['NickName']msg_time = msg['CreateTime']    #信息发送的时间msg_id = msg['MsgId']    #每条信息的idmsg_content = None      #储存信息的内容msg_share_url = None    #储存分享的链接,比如分享的文章和音乐#print ("msgType:"+msg['Type'])#print ("msgId:"+msg['MsgId'])if msg['Type'] == 'Text' or msg['Type'] == 'Friends':     #如果发送的消息是文本或者好友推荐msg_content = msg['Text']print (msg_from+':['+ msg['Type'] +']'+msg_content)#如果发送的消息是附件、视屏、图片、语音elif msg['Type'] == "Attachment" or msg['Type'] == "Video" \or msg['Type'] == 'Picture' \or msg['Type'] == 'Recording':msg_content = msg['FileName']    #内容就是他们的文件名msg['Text'](str(msg_content))    #下载文件print (msg_from+':['+ msg['Type'] +']'+msg_content)elif msg['Type'] == 'Card':    #如果消息是推荐的名片msg_content = msg['RecommendInfo']['NickName'] + '的名片'    #内容就是推荐人的昵称和性别if msg['RecommendInfo']['Sex'] == 1:msg_content += '性别为男'else:msg_content += '性别为女'print (msg_from+':['+ msg['Type'] +']'+msg_content)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"" + locationelif msg['Type'] == 'Sharing':     #如果消息为分享的音乐或者文章,详细的内容为文章的标题或者是分享的名字msg_content = msg['Text']msg_share_url = msg['Url']       #记录分享的urlprint (msg_from+':['+ msg['Type'] +']'+msg_content)face_bug=msg_content##将信息存储在字典中,每一个msg_id对应一条信息msg_information.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}})##这个是用于监听是否有friend消息撤回
@itchat.msg_register(NOTE, isFriendChat=True, isGroupChat=True, isMpChat=True)
def information(msg):#这里如果这里的msg['Content']中包含消息撤回和id,就执行下面的语句if '撤回了一条消息' in msg['Content']:old_msg_id = re.search("\<msgid\>(.*?)\<\/msgid\>", msg['Content']).group(1)   #在返回的content查找撤回的消息的idold_msg = msg_information.get(old_msg_id)    #得到消息print (old_msg)if len(old_msg_id)<11:  #如果发送的是表情包itchat.send_file(face_bug,toUserName='filehelper')else:  #发送撤回的提示给文件助手msg_body = old_msg.get('msg_time_rec') + "\n" \+"【" + old_msg.get('msg_from') + "】\n" \+ "撤回了" + old_msg.get("msg_type") + "类型的消息:" + "\n" \+ r"" + old_msg.get('msg_content')#如果是分享的文件被撤回了,那么就将分享的url加在msg_body中发送给文件助手if old_msg['msg_type'] == "Sharing":msg_body += "\n就是这个链接➣ " + old_msg.get('msg_share_url')# 将撤回消息发送到文件助手itchat.send_msg(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' % (old_msg['msg_content'])itchat.send(msg=file, toUserName='filehelper')os.remove(old_msg['msg_content'])# 删除字典旧消息msg_information.pop(old_msg_id)@itchat.msg_register([TEXT, PICTURE, FRIENDS, CARD, MAP, SHARING, RECORDING, ATTACHMENT, VIDEO], isGroupChat=True)
def handle_receive_msg(msg):global face_bugmsg_time_rec = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())   #接受消息的时间# groupid = msg['FromUserName']# chatroom = itchat.search_chatrooms(userName=groupid)msg_Actual_from = msg['ActualNickName']# msg_Actual_from = msg['User']# msg_from = msg_Actual_from['Self']['NickName']msg_from = msg_Actual_frommsg_time = msg['CreateTime']    #信息发送的时间msg_id = msg['MsgId']    #每条信息的idmsg_content = None      #储存信息的内容msg_share_url = None    #储存分享的链接,比如分享的文章和音乐print (msg['Type'])print (msg['MsgId'])if msg['Type'] == 'Text' or msg['Type'] == 'Friends':     #如果发送的消息是文本或者好友推荐msg_content = msg['Text']print (msg_content)#如果发送的消息是附件、视屏、图片、语音elif msg['Type'] == "Attachment" or msg['Type'] == "Video" \or msg['Type'] == 'Picture' \or msg['Type'] == 'Recording':msg_content = msg['FileName']    #内容就是他们的文件名msg['Text'](str(msg_content))    #下载文件# print (msg_content)elif msg['Type'] == 'Card':    #如果消息是推荐的名片msg_content = msg['RecommendInfo']['NickName'] + '的名片'    #内容就是推荐人的昵称和性别if msg['RecommendInfo']['Sex'] == 1:msg_content += '性别为男'else:msg_content += '性别为女'print (msg_content)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"" + locationelif msg['Type'] == 'Sharing':     #如果消息为分享的音乐或者文章,详细的内容为文章的标题或者是分享的名字msg_content = msg['Text']msg_share_url = msg['Url']       #记录分享的urlprint (msg_share_url)face_bug=msg_content##将信息存储在字典中,每一个msg_id对应一条信息msg_information.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}})#机器人回复取数接口
def get_response(msg):apiUrl='http://openapi.tuling123.com/openapi/api/v2'headers={"Content-Type":"application/json"}data={"reqType": 0,"perception": {"inputText": {"text": msg}},"userInfo": {"apiKey": "你的APIKEY","userId": "你的UserID"}}try:r = requests.post(url=apiUrl, headers=headers, data=json.dumps(data)).json()return r.get('results')[0].get("values").get("text")except Exception as e:return#自动回复功能
def handle_msg_reply(msg):global auto_reply, robot_reply, peer_list,peer_name_listtime.sleep(1) #延迟一秒if msg['Type'] != 'Text':itchat.send_msg(u'不支持的消息类型['+ msg['Type'] +']', msg['FromUserName'])returnmsg_content = msg['Text']name = 'Unknown Name'if msg['FromUserName'] == myUserName:if msg['Content'] == "reply mode on":auto_reply = Trueitchat.send_msg(u"自动回复功能已开启。\n", toUserName='filehelper')returnelif msg['Content'] == "reply mode off":auto_reply = Falseitchat.send_msg(u"自动回复功能已关闭。\n", toUserName='filehelper')returnelif msg['Content'] == "robot mode on":if msg['ToUserName'] not in peer_list:robot_reply = Truepeer_list.append(msg['ToUserName'])friend = itchat.search_friends(userName=msg['ToUserName'])if friend is not None:name = friend['NickName']peer_name_list.append(name)itchat.send_msg(u"为 "+name+" 添加机器人助手服务。\n服务列表:" + ','.join(peer_name_list) + "\n", toUserName='filehelper')returnelif msg['Content'] == "robot mode off":if msg['ToUserName'] in peer_list:robot_reply = Falsepeer_list.remove(msg['ToUserName'])friend = itchat.search_friends(userName=msg['ToUserName'])if friend is not None:name = friend['NickName']peer_name_list.remove(name)itchat.send_msg(u"关闭"+name+"机器人助手服务。\n服务列表:" + ','.join(peer_name_list) + "\n", toUserName='filehelper')return    #自动回复 机器回复 只使用一种方式回复else:if auto_reply == True:itchat.send_msg(u"[自动回复]您好,我现在有事不在,一会儿再联系你。\n", msg['FromUserName'])elif robot_reply == True and msg['FromUserName'] in peer_list:itchat.send_msg(get_response(msg_content), msg['FromUserName'])##这个是用于监听是否有Group消息撤回
@itchat.msg_register(NOTE, isGroupChat=True, isMpChat=True)
def information(msg):#这里如果这里的msg['Content']中包含消息撤回和id,就执行下面的语句if '撤回了一条消息' in msg['Content']:old_msg_id = re.search("\<msgid\>(.*?)\<\/msgid\>", msg['Content']).group(1)   #在返回的content查找撤回的消息的idold_msg = msg_information.get(old_msg_id)    #得到消息print (old_msg)if len(old_msg_id)<11:  #如果发送的是表情包itchat.send_file(face_bug,toUserName='filehelper')else:  #发送撤回的提示给文件助手msg_body = old_msg.get('msg_time_rec') + "\n" \+ "【" + old_msg.get('msg_from') + " 群消息撤回提醒】\n"\+ " 撤回了 " + old_msg.get("msg_type") + "类型的消息:" + "\n" \+ r"" + old_msg.get('msg_content')#如果是分享的文件被撤回了,那么就将分享的url加在msg_body中发送给文件助手if old_msg['msg_type'] == "Sharing":msg_body += "\n就是这个链接➣ " + old_msg.get('msg_share_url')# 将撤回消息发送到文件助手itchat.send_msg(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' % (old_msg['msg_content'])itchat.send(msg=file, toUserName='filehelper')os.remove(old_msg['msg_content'])# 删除字典旧消息msg_information.pop(old_msg_id)# Main
itchat.auto_login(enableCmdQR=True, hotReload=True)
myUserName = itchat.get_friends(update = True)[0]["UserName"]
itchat.run()

全文完,希望你有所收获。

微信消息防撤回 + 智能聊天机器 Python itchat实现相关推荐

  1. Python实现微信消息防撤回

    微信(WeChat)是腾讯公司于2011年1月21日推出的一款社交软件,8年时间微信做到日活10亿,日消息量450亿.在此期间微信也推出了不少的功能如:"摇一摇"."漂流 ...

  2. #Python #微信 #消息防撤回 Python实现微信防撤回

    微信(WeChat)是腾讯公司于2011年1月21日推出的一款社交软件,8年时间微信做到日活10亿,日消息量450亿.在此期间微信也推出了不少的功能如:"摇一摇"."漂流 ...

  3. 微信防撤回python代码_python实现微信消息防撤回

    微信(WeChat)是腾讯公司于2011年1月21日推出的一款社交软件,8年时间微信做到日活10亿,日消息量450亿.在此期间微信也推出了不少的功能如:"摇一摇"."漂 ...

  4. 微信防撤回python_python使用wxpy实现微信消息防撤回脚本

    本文实例为大家分享了python实现微信消息防撤回的具体代码,供大家参考,具体内容如下 使用了sqlite3保存数据,当有人撤回消息时取出数据发送到文件传输助手. 文件的话会先保存到本地,语音会以文件 ...

  5. 微信消息防撤回,这款开源神器文字、语音、图片都支持撤回查看!

    前言 微信在2014年的时候,发布的v5.3.1 版本中推出了消息撤回功能,用户可以选择撤回 2 分钟内发送的最后一条信息. 现在很多即时通讯的软件都有撤回这个功能. 腾讯为了照顾手残党,在微信和QQ ...

  6. 如何使用 Python 实现微信消息防撤回

    在微信上突然看到"XXX撤回一条消息"的时候,心里痒不痒?现在就教你如何实现消息防撤回的功能.不限手机型号.手机无需root,只要微信号可以登上网页版就可以了(部分不常用和新申请的 ...

  7. 微信多开工具,微信防撤回、QQ防撤回、Tim防撤回工具,微信消息防撤回、QQ消息防撤回、Tim消息防撤回,无视撤回功能,不错过每一条消息

    这是一款非常小巧精致的防撤回和微信多开工具,只有130kb的大小,但功能却非常强大. 一.软件简介 这是一个开源项目,程序源码全部开源,因此这款工具具有极高的安全性,毕竟代码就公开在大家的眼皮底下,谁 ...

  8. 用python实现语音的传输功能_用Python+WechatPCAPI实现微信消息防撤回

    干货分享 干货 | Python学习资源整理分享​mp.weixin.qq.com 引言 最近逛GitHub时发现了一个半开源的微信PC版的API接口WechatPCAPI,研究了一下,发现还是很好用 ...

  9. 用Python+WechatPCAPI实现微信消息防撤回

    干货 二十多本Python好书,从入门到进阶,点这自取 引言 最近逛GitHub时发现了一个半开源的微信PC版的API接口WechatPCAPI,研究了一下,发现还是很好用的,所以就顺便用这个库写了个 ...

最新文章

  1. mpi并行 java_【并行计算】用MPI进行分布式内存编程(一)
  2. 新型智能头盔可快速评估患者中风的大小、位置和类型
  3. mplayer最全的命令
  4. linux wheel组
  5. HTTP 1.1与HTTP 1.0的比较
  6. 深度剖析SOC高性能实时事件关联分析引擎
  7. GCD API 理解 (一)
  8. Python实例讲解 -- tkinter canvas (设置背景图片及文字)
  9. 【李宏毅2020 ML/DL】P2 Regressio - Case Study
  10. 怎么用计算机看,如何巧妙的查看电脑使用痕迹
  11. Oracle 默认表空间(default permanent tablespace) 说明
  12. 罗永浩宣布年后回归科技界!下一代平台上见 网友:暗示年后“真还传”要完结...
  13. 关于php单引号和双引号
  14. Promise 的 9 个提示
  15. 程序员必备的八大排序算法
  16. 用JavaScript做一个日历和用canvas做一个时钟
  17. java 成神之路 (一)
  18. php mysql购物网站_php实现一个简单的购物网站
  19. java 调用felix_使用eclipse开发felix的OSGI插件
  20. 在线生成安卓APP图标

热门文章

  1. 喷涂硬质聚氨酯(PUR)和聚异氰脲酯(PIR)泡沫保温材料英国UKCA 认证—EN 14320-1
  2. 开源云管平台有哪些?有哪些优势?
  3. 职场生存技能-测试人员甩锅指南
  4. 如何清除Microsoft Teams的缓存
  5. 水客欲替代黄牛党 超5000部水货iPhone 6进京
  6. Excel 函数进阶
  7. 电脑截图方法快捷键等介绍
  8. win10复制粘贴linux,如何在Windows 10的Bash Shell中启用复制和粘贴键盘快捷键 | MOS86...
  9. 用Netty开发中间件:网络编程基础
  10. Echarts饼图标题文字居中