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

注意:这里用了一个wechat库,当然,wechat库是基于微信提供的官方接口实现的。

这里的核心就是通过网页登陆微信的方式,然后获取各个通讯信息,然后存进内存,最后检测各种微信的操作,最后写入微信里面的文件传输助手即可。

直接看代码,然后运行,慢慢调试几次,就明白咋回事了。

#coding=utf8

import itchat

import requests

import time

import os

import re

import threading

#全局变量,对于每个用户的机器人开关

User_bot_control_flag = {}

#全局变量,我的昵称

myNickName = ''

def bot_chat_init():

# 获取好友列表

friends = itchat.get_friends(update=True)[0:]

#将标志位置为0

for i in friends[1:]:

User_bot_control_flag[i["UserName"]] = 0

@itchat.msg_register(itchat.content.TEXT)

def tuling_reply(msg):

# 获取到发送消息者身份,如果身份匹配,就做对应的事

# itchat.send_msg('已经收到了文本消息,消息内容为%s' % msg['Text'], toUserName=msg['FromUserName'])

# 如果图灵Key出现问题,那么reply将会是None

if msg['Text']=='service crond start':

return u'你一看就是个程序员'

if msg['Text'] == 'dididididi':

return u'开车了'

reply = get_response(msg['Text'])

if not msg['FromUserName'] == myUserName:

pass

# 发送一条提示给文件助手

# itchat.send_msg(u"[%s]收到好友@%s 的信息:%s\n" %

# (time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(msg['CreateTime'])),

# msg['User']['NickName'],

# msg['Text']), 'filehelper')

# a or b的意思是,如果a有内容,那么返回a,否则返回b

# 有内容一般就是指非空或者非None,你可以用`if a: print('True')`来测试

return reply or u'[自动回复]您好,我现在有事不在,一会再和您联系。\n已经收到您的的信息:%s\n' % (msg['Text'])

def friend():

# 初始化计数器,有男有女,当然,有些人是不填的

# 获取好友列表

friends = itchat.get_friends(update=True)[0:]

male = female = other = 0

# 遍历这个列表,列表里第一位是自己,所以从"自己"之后开始计算

# 1表示男性,2女性

for i in friends[1:]:

print (i) #打印出签名

sex = i["Sex"]

if sex == 1:

male += 1

elif sex == 2:

female += 1

else:

other += 1

# 总数算上,好计算比例啊~

total = len(friends[1:])

# 好了,打印结果

print(u"共有好友:%d" % total)

print (u"男性好友:%.2f%%" % (float(male) / total * 100))

print (u"女性好友:%.2f%%" % (float(female) / total * 100))

print (u"其他:%.2f%%" % (float(other) / total * 100))

def get_response(msg):

# 这里我们就像在“3. 实现最简单的与图灵机器人的交互”中做的一样

# 构造了要发送给服务器的数据

apiUrl = 'http://www.tuling123.com/openapi/api'

data = {

'key' : key,

'info' : msg,

'userid' : 'wechat-robot',

}

try:

r = requests.post(apiUrl, data=data).json()

# 字典的get方法在字典没有'text'值的时候会返回None而不会抛出异常

return r.get('text')+'----来自机器人小Z的智能回复----'

# 为了防止服务器没有正常响应导致程序异常退出,这里用try-except捕获了异常

# 如果服务器没能正常交互(返回非json或无法连接),那么就会进入下面的return

except:

# 将会返回一个None

return

@itchat.msg_register(itchat.content.TEXT, isGroupChat=True) #msg['ActualNickName'] 群里发消息的人名 #msg['User']['NickName'] 群名称

def text_reply(msg):

# print (msg['User']) #一个宏大的结构体

# print ("群聊名字"+msg['User']['NickName']) #群聊名称

# print (msg['FromUserName'])

#监控所有群的消息,后来做统计用,后面可以做关键词分析什么的

file_object = open(myNickName+"群"+msg['User']['NickName'], 'a')

write_data = ''.join(time.strftime("%Y-%m-%d %H:%M:%S" , time.localtime(msg['CreateTime'])))+" "+msg['ActualNickName']+": "+msg['Text']+"\n"

file_object.write(write_data)

file_object.close()

#指定群聊可以智能群聊

if msg['User']['NickName'] == '184':

print (" 184 ok")

itchat.send(get_response(msg['Text']),msg['FromUserName'])

#监控群聊内容发送到文件助手,已经被自己屏蔽掉了

# itchat.send_msg(u"[%s]收到%s群 %s 的信息:%s\n" %

# (time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(msg['CreateTime']))

# ,msg['User']['NickName'],msg['ActualNickName'],

# msg['Text']), 'filehelper')

# 判断是否有人@自己

if (msg.isAt):

# 如果有人@自己,就发一个消息告诉对方我已经收到了信息

itchat.send_msg("我已经收到了来自{0}的消息,实际内容为{1}".format(msg['ActualNickName'], msg['Text']),

toUserName=msg['FromUserName'])

# def sendmsgToPsh():

# while (True):

# pass

# # print ("123456")

#

# threads = []

# t1 = threading.Thread(target=sendmsgToPsh())

# 说明:可以撤回的有文本文字、语音、视频、图片、位置、名片、分享、附件

# {msg_id:(msg_from,msg_to,msg_time,msg_time_rec,msg_type,msg_content,msg_share_url)}

msg_dict = {}

# 文件存储临时目录

rev_tmp_dir = "/home/seen/PycharmProjects/Code"

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([itchat.content.TEXT, itchat.content.PICTURE, itchat.content.MAP, itchat.content.CARD, itchat.content.SHARING,

# itchat.content.RECORDING,itchat.content. ATTACHMENT, itchat.content.VIDEO],isGroupChat=True)

# def handler_receive_msg(msg):

# #回复特定用户消息

# # if msg['User']['NickName']=='YYYYY' or msg['User']['NickName']=='彭芊芊':

# # print ("yhj ok")

# # itchat.send_msg(get_response(msg['Text']), toUserName=msg['FromUserName'])

# # 先获取对方说来的话

# # 下面一行是获取发送消息者昵称

# send_user_name = itchat.search_friends(userName=msg['FromUserName'])['NickName']

# file_object = open(myNickName + "&" + msg['User']['NickName'], 'a')

# write_data = ''.join(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(msg['CreateTime']))) + " " + \

# send_user_name + ": " + msg['Text'] + "\n"

# file_object.write(write_data)

# file_object.close()

#

# #控制指令检测模块

# if msg['Text'] == 'service robot start':

# User_bot_control_flag[msg['FromUserName']]=1 #检测到开启指令后开启机器人

# itchat.send_msg("Robot small Z started...waiting for your service", toUserName=msg['FromUserName'])

# if msg['Text'] == 'service robot stop':

# User_bot_control_flag[msg['FromUserName']]=0 #检测到开启指令后关闭机器人

# itchat.send_msg("Robot small Z stoped...get 'service robot start' restarted", toUserName=msg['FromUserName'])

# #在开关开启的情况下回复对方对话

# if not msg['FromUserName'] == myUserName:

# if User_bot_control_flag[msg['FromUserName']]:

# # 存储单人对话模块

# # 下面一行是获取发送消息者昵称

# reply = get_response(msg['Text'])

# file_object = open(myNickName + "&" + msg['User']['NickName'], 'a')

# write_data = ''.join(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(msg['CreateTime']))) + " " + \

# myNickName + ": " + reply + "\n"

# file_object.write(write_data)

# file_object.close()

# itchat.send_msg(reply, toUserName=msg['FromUserName'])

#

# 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(

# "

# 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

# }

# }

# )

# 将接收到的消息存放在字典中,当接收到新消息时对字典中超时的消息进行清理 | 不接受不具有撤回功能的信息

# [TEXT, PICTURE, MAP, CARD, SHARING, RECORDING, ATTACHMENT, VIDEO, FRIENDS, NOTE]

@itchat.msg_register([itchat.content.TEXT, itchat.content.PICTURE, itchat.content.MAP, itchat.content.CARD, itchat.content.SHARING,

itchat.content.RECORDING,itchat.content. ATTACHMENT, itchat.content.VIDEO])

def handler_receive_msg(msg):

#回复特定用户消息

# if msg['User']['NickName']=='YYYYY' or msg['User']['NickName']=='彭芊芊':

# print ("yhj ok")

# itchat.send_msg(get_response(msg['Text']), toUserName=msg['FromUserName'])

# 先获取对方说来的话

# 下面一行是获取发送消息者昵称

send_user_name = itchat.search_friends(userName=msg['FromUserName'])['NickName']

file_object = open(myNickName + "&" + msg['User']['NickName'], 'a')

write_data = ''.join(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(msg['CreateTime']))) + " " + \

send_user_name + ": " + msg['Text'] + "\n"

file_object.write(write_data)

file_object.close()

#控制指令检测模块

if msg['Text'] == 'service robot start':

User_bot_control_flag[msg['FromUserName']]=1 #检测到开启指令后开启机器人

itchat.send_msg("Robot small Z started...waiting for your service", toUserName=msg['FromUserName'])

if msg['Text'] == 'service robot stop':

User_bot_control_flag[msg['FromUserName']]=0 #检测到开启指令后关闭机器人

itchat.send_msg("Robot small Z stoped...get 'service robot start' restarted", toUserName=msg['FromUserName'])

#在开关开启的情况下回复对方对话

if not msg['FromUserName'] == myUserName:

if User_bot_control_flag[msg['FromUserName']]:

# 存储单人对话模块

# 下面一行是获取发送消息者昵称

reply = get_response(msg['Text'])

file_object = open(myNickName + "&" + msg['User']['NickName'], 'a')

write_data = ''.join(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(msg['CreateTime']))) + " " + \

myNickName + ": " + reply + "\n"

file_object.write(write_data)

file_object.close()

itchat.send_msg(reply, toUserName=msg['FromUserName'])

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(

"

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([itchat.content.NOTE],isGroupChat=True)

# def send_msg_helper(msg):

# global face_bug

# if re.search(r"\", msg['Content']) is not None:

# # 获取消息的id

# old_msg_id = re.search("\(.*?)\", 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 = "告诉你一个秘密~" + "\n" \

# + old_msg.get('msg_from') + " 撤回了 " + old_msg.get("msg_type") + " 消息" + "\n" \

# + old_msg.get('msg_time_rec') + "\n" \

# + "撤回了什么 ⇣" + "\n" \

# + r"" + old_msg.get('msg_content')

# # 如果是分享存在链接

# 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)

# 收到note通知类消息,判断是不是撤回并进行相应操作

@itchat.msg_register([itchat.content.NOTE])

def send_msg_helper(msg):

global face_bug

if re.search(r"\", msg['Content']) is not None:

# 获取消息的id

old_msg_id = re.search("\(.*?)\", 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 = "告诉你一个秘密~" + "\n" \

+ old_msg.get('msg_from') + " 撤回了 " + old_msg.get("msg_type") + " 消息" + "\n" \

+ old_msg.get('msg_time_rec') + "\n" \

+ "撤回了什么 ⇣" + "\n" \

+ r"" + old_msg.get('msg_content')

# 如果是分享存在链接

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)

key = '02dd1dd1b5594e179aa4aca9a6a690a6'

if __name__ == '__main__':

itchat.auto_login(hotReload=True)

# 获取自己的UserName

myNickName = itchat.get_friends(update=True)[0]["NickName"]

myUserName = itchat.get_friends(update=True)[0]["UserName"]

#做函数功能的实验

# print (itchat.search_friends(name='彭芊芊')[0]['UserName']) #我居然会用了这种办法我是真的猛

# print(type(itchat.search_friends(name='彭芊芊')))

#itchat.send("init messages to dindsong,A message from bangbangtang,distant areas...", toUserName='@509f2668d9380a6aeb1951585256827dc1d475c2de885b62fae401401d522f9b')

friend() #获取朋友信息

bot_chat_init() #初始化开关模块

itchat.run()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

python撤回指令程序_python微信撤回监测代码相关推荐

  1. python画图代码-Python实战小程序利用matplotlib模块画图代码分享

    Python中的数据可视化 matplotlib 是python最著名的绘图库,它提供了一整套和matlab相似的命令API,十分适合交互式地进行制图.而且也可以方便地将它作为绘图控件. 实战小程序: ...

  2. 用python画图代码-Python实战小程序利用matplotlib模块画图代码分享

    Python中的数据可视化 matplotlib 是python最著名的绘图库,它提供了一整套和matlab相似的命令API,十分适合交互式地进行制图.而且也可以方便地将它作为绘图控件. 实战小程序: ...

  3. python编写表白程序_python如何写出表白程序

    用python编表白程序的方法: 1.创建GUI窗口,实现代码的调用. 2.编写点击触发函数,实现表白程序. 具体代码如下: from tkinter import * from tkinter im ...

  4. python判断素数程序_Python程序检查素数

    python判断素数程序 什么是质数? (What is a prime number?) A prime number is a natural number that is greater tha ...

  5. python二分法查找程序_Python程序查找最大EVEN数

    python二分法查找程序 Input N integer numbers and we have to find the maximum even number. 输入N个整数,我们必须找到最大的偶 ...

  6. python二分法查找程序_Python程序查找地板划分

    python二分法查找程序 When we divide a number by another number – division operator (/) return quotient it m ...

  7. python自我复制的程序_Python自我

    python自我复制的程序 In this lesson, we will study about the usage of Python self. It is often a point of d ...

  8. python判断素数程序_python素数判断

    广告关闭 腾讯云11.11云上盛惠 ,精选热门产品助力上云,云服务器首年88元起,买的越多返的越多,最高返5000元! 质数(prime number),又称素数,指在大于1的自然数中,除了1和该数自 ...

  9. python编写hello程序_python第一个程序“Hello, world”

    python第一个程序 无论通过哪种方式使用Python的交互模式,都应该看到由3个三角括号">>>"组成的提示符.这就是Python的命令行提示符,表示可以键入 ...

最新文章

  1. Java语言的关键字
  2. stopping NetworkManager daemon failed
  3. 如何用 Nginx 在公网上搭建加密数据通道
  4. amazon redshift 分析型数据库特点——本质还是列存储
  5. Python中如何写控制台进度条的整理
  6. C#中格式化小数位数为指定位数的工具类
  7. REST设计模式简介
  8. rabbitMQ教程 spring整合rabbitMQ代码实例
  9. 每日一小练——按字典顺序列出全部子集
  10. 在Saas发展的黄金时代里带你理解SaaS设计
  11. 各种系统程序更新链接
  12. python自动交易app_股票自动交易Python下单接口
  13. 一次性通过CISSP考试之旅
  14. 从毕业生到高级工程师:三位腾讯高级程序员的感悟
  15. 六级考研单词之路-三十二
  16. html span向上对齐,css也能让span靠左布局
  17. 韦小宝真的幸福吗 | Random Forest
  18. NDN-lite 命名数据网络 -----第二章:对Interest和Data包的处理
  19. 怎么做才可以把电脑上的照片给做成视频?-markdown编辑器
  20. Error:UserServiceImpl不是抽象的, 并且未覆盖UserService中的抽象方法

热门文章

  1. 【鸿蒙】数据管理--关系型数据库
  2. java 数字转汉字思路,数字转中文的方法
  3. 牢记17个的Windos快捷键,告别鼠标 !
  4. Unity UGUI通过摇杆joystick 控制角色移动 标准的第三人称视角手游-左侧控制移动,右侧控制视角和方向
  5. 【卡塔尔世界杯】空调制冷,全是科技与狠活
  6. 1分钟链圈 | 闪电网络通道数增加29.5%,突破1.1万条通道!EOS 在过去七天区块链活跃度中排名第一...
  7. 北邮2020 计算机网络抓包实验报告
  8. 最懂你的服装设计师是AI?让用户 “凭心意” 生成数字服装#Adidas OZWORLD
  9. golang编码一致性哈希算法
  10. matlab根据行列标题索引表格数据