python微信撤回監(jiān)測代碼
本文實(shí)例為大家分享了python微信撤回的監(jiān)測代碼,供大家參考,具體內(nèi)容如下
注意:這里用了一個(gè)wechat庫,當(dāng)然,wechat庫是基于微信提供的官方接口實(shí)現(xiàn)的。
這里的核心就是通過網(wǎng)頁登陸微信的方式,然后獲取各個(gè)通訊信息,然后存進(jìn)內(nèi)存,最后檢測各種微信的操作,最后寫入微信里面的文件傳輸助手即可。
直接看代碼,然后運(yùn)行,慢慢調(diào)試幾次,就明白咋回事了。
#coding=utf8
import itchat
import requests
import time
import os
import re
import threading
#全局變量,對于每個(gè)用戶的機(jī)器人開關(guān)
User_bot_control_flag = {}
#全局變量,我的昵稱
myNickName = ''
def bot_chat_init():
# 獲取好友列表
friends = itchat.get_friends(update=True)[0:]
#將標(biāo)志位置為0
for i in friends[1:]:
User_bot_control_flag[i["UserName"]] = 0
@itchat.msg_register(itchat.content.TEXT)
def tuling_reply(msg):
# 獲取到發(fā)送消息者身份,如果身份匹配,就做對應(yīng)的事
# itchat.send_msg('已經(jīng)收到了文本消息,消息內(nèi)容為%s' % msg['Text'], toUserName=msg['FromUserName'])
# 如果圖靈Key出現(xiàn)問題,那么reply將會(huì)是None
if msg['Text']=='service crond start':
return u'你一看就是個(gè)程序員'
if msg['Text'] == 'dididididi':
return u'開車了'
reply = get_response(msg['Text'])
if not msg['FromUserName'] == myUserName:
pass
# 發(fā)送一條提示給文件助手
# 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有內(nèi)容,那么返回a,否則返回b
# 有內(nèi)容一般就是指非空或者非None,你可以用`if a: print('True')`來測試
return reply or u'[自動(dòng)回復(fù)]您好,我現(xiàn)在有事不在,一會(huì)再和您聯(lián)系。\n已經(jīng)收到您的的信息:%s\n' % (msg['Text'])
def friend():
# 初始化計(jì)數(shù)器,有男有女,當(dāng)然,有些人是不填的
# 獲取好友列表
friends = itchat.get_friends(update=True)[0:]
male = female = other = 0
# 遍歷這個(gè)列表,列表里第一位是自己,所以從"自己"之后開始計(jì)算
# 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
# 總數(shù)算上,好計(jì)算比例啊~
total = len(friends[1:])
# 好了,打印結(jié)果
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. 實(shí)現(xiàn)最簡單的與圖靈機(jī)器人的交互”中做的一樣
# 構(gòu)造了要發(fā)送給服務(wù)器的數(shù)據(jù)
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'值的時(shí)候會(huì)返回None而不會(huì)拋出異常
return r.get('text')+'----來自機(jī)器人小Z的智能回復(fù)----'
# 為了防止服務(wù)器沒有正常響應(yīng)導(dǎo)致程序異常退出,這里用try-except捕獲了異常
# 如果服務(wù)器沒能正常交互(返回非json或無法連接),那么就會(huì)進(jìn)入下面的return
except:
# 將會(huì)返回一個(gè)None
return
@itchat.msg_register(itchat.content.TEXT, isGroupChat=True) #msg['ActualNickName'] 群里發(fā)消息的人名 #msg['User']['NickName'] 群名稱
def text_reply(msg):
# print (msg['User']) #一個(gè)宏大的結(jié)構(gòu)體
# print ("群聊名字"+msg['User']['NickName']) #群聊名稱
# print (msg['FromUserName'])
#監(jiān)控所有群的消息,后來做統(tǒng)計(jì)用,后面可以做關(guān)鍵詞分析什么的
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'])
#監(jiān)控群聊內(nèi)容發(fā)送到文件助手,已經(jīng)被自己屏蔽掉了
# 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):
# 如果有人@自己,就發(fā)一個(gè)消息告訴對方我已經(jīng)收到了信息
itchat.send_msg("我已經(jīng)收到了來自{0}的消息,實(shí)際內(nèi)容為{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 = {}
# 文件存儲(chǔ)臨時(shí)目錄
rev_tmp_dir = "/home/seen/PycharmProjects/Code"
if not os.path.exists(rev_tmp_dir): os.mkdir(rev_tmp_dir)
# 表情有一個(gè)問題 | 接受信息和接受note的msg_id不一致 巧合解決方案
face_bug = None
# # 將接收到的消息存放在字典中,當(dāng)接收到新消息時(shí)對字典中超時(shí)的消息進(jìn)行清理 | 不接受不具有撤回功能的信息
# # [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):
# #回復(fù)特定用戶消息
# # if msg['User']['NickName']=='YYYYY' or msg['User']['NickName']=='彭芊芊':
# # print ("yhj ok")
# # itchat.send_msg(get_response(msg['Text']), toUserName=msg['FromUserName'])
# # 先獲取對方說來的話
# # 下面一行是獲取發(fā)送消息者昵稱
# 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 #檢測到開啟指令后開啟機(jī)器人
# 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 #檢測到開啟指令后關(guān)閉機(jī)器人
# itchat.send_msg("Robot small Z stoped...get 'service robot start' restarted", toUserName=msg['FromUserName'])
# #在開關(guān)開啟的情況下回復(fù)對方對話
# if not msg['FromUserName'] == myUserName:
# if User_bot_control_flag[msg['FromUserName']]:
# # 存儲(chǔ)單人對話模塊
# # 下面一行是獲取發(fā)送消息者昵稱
# 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
# # 獲取的是本地時(shí)間戳并格式化本地時(shí)間戳 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']
# # 消息時(shí)間
# msg_time = msg['CreateTime']
# # 消息發(fā)送人昵稱 | 這里也可以使用RemarkName備注 但是自己或者沒有備注的人為None
# msg_from = (itchat.search_friends(userName=msg['FromUserName']))["NickName"]
# # 消息內(nèi)容
# 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(
# "<location x=\"(.*?)\" y=\"(.*?)\".*label=\"(.*?)\".*", msg['OriContent']).group(1, 2, 3)
# if location is None:
# msg_content = r"緯度->" + x.__str__() + " 經(jīng)度->" + 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
# }
# }
# )
# 將接收到的消息存放在字典中,當(dāng)接收到新消息時(shí)對字典中超時(shí)的消息進(jìn)行清理 | 不接受不具有撤回功能的信息
# [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):
#回復(fù)特定用戶消息
# if msg['User']['NickName']=='YYYYY' or msg['User']['NickName']=='彭芊芊':
# print ("yhj ok")
# itchat.send_msg(get_response(msg['Text']), toUserName=msg['FromUserName'])
# 先獲取對方說來的話
# 下面一行是獲取發(fā)送消息者昵稱
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 #檢測到開啟指令后開啟機(jī)器人
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 #檢測到開啟指令后關(guān)閉機(jī)器人
itchat.send_msg("Robot small Z stoped...get 'service robot start' restarted", toUserName=msg['FromUserName'])
#在開關(guān)開啟的情況下回復(fù)對方對話
if not msg['FromUserName'] == myUserName:
if User_bot_control_flag[msg['FromUserName']]:
# 存儲(chǔ)單人對話模塊
# 下面一行是獲取發(fā)送消息者昵稱
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
# 獲取的是本地時(shí)間戳并格式化本地時(shí)間戳 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']
# 消息時(shí)間
msg_time = msg['CreateTime']
# 消息發(fā)送人昵稱 | 這里也可以使用RemarkName備注 但是自己或者沒有備注的人為None
msg_from = (itchat.search_friends(userName=msg['FromUserName']))["NickName"]
# 消息內(nèi)容
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(
"<location x=\"(.*?)\" y=\"(.*?)\".*label=\"(.*?)\".*", msg['OriContent']).group(1, 2, 3)
if location is None:
msg_content = r"緯度->" + x.__str__() + " 經(jīng)度->" + 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通知類消息,判斷是不是撤回并進(jìn)行相應(yīng)操作,針對于群
# @itchat.msg_register([itchat.content.NOTE],isGroupChat=True)
# def send_msg_helper(msg):
# global face_bug
# if re.search(r"\<\!\[CDATA\[.*撤回了一條消息\]\]\>", msg['Content']) is not None:
# # 獲取消息的id
# 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 = "告訴你一個(gè)秘密~" + "\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就是這個(gè)鏈接➣ " + old_msg.get('msg_share_url')
#
# # 將撤回消息發(fā)送到文件助手
# itchat.send(msg_body, toUserName='filehelper')
# # 有文件的話也要將文件發(fā)送回去
# 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通知類消息,判斷是不是撤回并進(jìn)行相應(yīng)操作
@itchat.msg_register([itchat.content.NOTE])
def send_msg_helper(msg):
global face_bug
if re.search(r"\<\!\[CDATA\[.*撤回了一條消息\]\]\>", msg['Content']) is not None:
# 獲取消息的id
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 = "告訴你一個(gè)秘密~" + "\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就是這個(gè)鏈接➣ " + old_msg.get('msg_share_url')
# 將撤回消息發(fā)送到文件助手
itchat.send(msg_body, toUserName='filehelper')
# 有文件的話也要將文件發(fā)送回去
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"]
#做函數(shù)功能的實(shí)驗(yàn)
# print (itchat.search_friends(name='彭芊芊')[0]['UserName']) #我居然會(huì)用了這種辦法我是真的猛
# print(type(itchat.search_friends(name='彭芊芊')))
#itchat.send("init messages to dindsong,A message from bangbangtang,distant areas...", toUserName='@509f2668d9380a6aeb1951585256827dc1d475c2de885b62fae401401d522f9b')
friend() #獲取朋友信息
bot_chat_init() #初始化開關(guān)模塊
itchat.run()
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
使用Django搭建web服務(wù)器的例子(最最正確的方式)
今天小編就為大家分享一篇使用Django搭建web服務(wù)器的例子(最最正確的方式),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08
Pandas之使用drop_duplicates:去除重復(fù)項(xiàng)
這篇文章主要介紹了Pandas之使用drop_duplicates:去除重復(fù)項(xiàng)方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
python中常用的數(shù)據(jù)結(jié)構(gòu)介紹
這篇文章主要介紹了python中常用的數(shù)據(jù)結(jié)構(gòu)介紹,幫助大家更好的理解和學(xué)習(xí)python的基礎(chǔ)知識,感興趣的朋友可以了解下2021-01-01
Pytorch參數(shù)注冊和nn.ModuleList nn.ModuleDict的問題
這篇文章主要介紹了Pytorch參數(shù)注冊和nn.ModuleList nn.ModuleDict的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
python+html實(shí)現(xiàn)前后端數(shù)據(jù)交互界面顯示的全過程
最近項(xiàng)目中采用了前后端分離的技術(shù),感覺有必要給大家總結(jié)下,所以下面這篇文章主要給大家介紹了關(guān)于python+html實(shí)現(xiàn)前后端數(shù)據(jù)交互界面顯示的相關(guān)資料,需要的朋友可以參考下2022-06-06
PyChon中關(guān)于Jekins的詳細(xì)安裝(推薦)
這篇文章主要介紹了PyChon中關(guān)于Jekins的詳細(xì)安裝(推薦),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12
利用numpy實(shí)現(xiàn)一、二維數(shù)組的拼接簡單代碼示例
這篇文章主要介紹了利用numpy實(shí)現(xiàn)一、二維數(shù)組的拼接簡單代碼示例,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12

