首页 后端开发 Python教程 python查看微信好友是否删除自己

python查看微信好友是否删除自己

Jan 18, 2017 pm 03:52 PM

Python编程语言

Python 是一种面向对象、解释型计算机程序设计语言,由Guido van Rossum于1989年底发明,第一个公开发行版发行于1991年。Python语法简洁而清晰,具有丰富和强大的类库。它常被昵称为胶水语言,它能够把用其他语言制作的各种模块(尤其是C/C++)很轻松地联结在一起。


这篇文章主要为大家详细介绍了python查看微信好友是否删除自己,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了python微信好友删除的具体代码,供大家参考,具体内容如下

#weixin.py
#coding:utf-8
# !/usr/bin/env python
# coding=utf-8

#通过该程序可以发现被删除的好友

import os
import urllib, urllib2
import re
import cookielib
import time
import xml.dom.minidom
import json
import sys
import math

DEBUG = False

MAX_GROUP_NUM = 35 # 每组人数

QRImagePath = os.getcwd() + '/qrcode.jpg'

tip = 0
uuid = ''

base_uri = ''
redirect_uri = ''

skey = ''
wxsid = ''
wxuin = ''
pass_ticket = ''
deviceId = 'e000000000000000'

BaseRequest = {}

ContactList = []
My = []


def getUUID():
  global uuid

  url = 'https://login.weixin.qq.com/jslogin'
  params = {
    'appid': 'wx782c26e4c19acffb',
    'fun': 'new',
    'lang': 'zh_CN',
    '_': int(time.time()),
  }

  request = urllib2.Request(url=url, data=urllib.urlencode(params))
  response = urllib2.urlopen(request)
  data = response.read()

  # print data

  # window.QRLogin.code = 200; window.QRLogin.uuid = "oZwt_bFfRg==";
  regx = r'window.QRLogin.code = (\d+); window.QRLogin.uuid = "(\S+?)"'
  pm = re.search(regx, data)

  code = pm.group(1)
  uuid = pm.group(2)

  if code == '200':
    return True

  return False


def showQRImage():
  global tip

  url = 'https://login.weixin.qq.com/qrcode/' + uuid
  params = {
    't': 'webwx',
    '_': int(time.time()),
  }

  request = urllib2.Request(url=url, data=urllib.urlencode(params))
  response = urllib2.urlopen(request)

  tip = 1

  f = open(QRImagePath, 'wb')
  f.write(response.read())
  f.close()

  if sys.platform.find('darwin') >= 0:
    os.system('open %s' % QRImagePath)
  elif sys.platform.find('linux') >= 0:
    os.system('xdg-open %s' % QRImagePath)
  else:
    os.system('call %s' % QRImagePath)

  print '请使用微信扫描二维码以登录'


def waitForLogin():
  global tip, base_uri, redirect_uri

  url = 'https://login.weixin.qq.com/cgi-bin/mmwebwx-bin/login?tip=%s&uuid=%s&_=%s' % (tip, uuid, int(time.time()))

  request = urllib2.Request(url=url)
  response = urllib2.urlopen(request)
  data = response.read()

  # print data

  # window.code=500;
  regx = r'window.code=(\d+);'
  pm = re.search(regx, data)

  code = pm.group(1)

  if code == '201': # 已扫描
    print '成功扫描,请在手机上点击确认以登录'
    tip = 0
  elif code == '200': # 已登录
    print '正在登录...'
    regx = r'window.redirect_uri="(\S+?)";'
    pm = re.search(regx, data)
    redirect_uri = pm.group(1) + '&fun=new'
    base_uri = redirect_uri[:redirect_uri.rfind('/')]
  elif code == '408': # 超时
    pass
  # elif code == '400' or code == '500':

  return code


def login():
  global skey, wxsid, wxuin, pass_ticket, BaseRequest

  request = urllib2.Request(url=redirect_uri)
  response = urllib2.urlopen(request)
  data = response.read()

  # print data

  '''
   <error>
    <ret>0</ret>
    <message>OK</message>
    <skey>xxx</skey>
    <wxsid>xxx</wxsid>
    <wxuin>xxx</wxuin>
    <pass_ticket>xxx</pass_ticket>
    <isgrayscale>1</isgrayscale>
   </error>
  &#39;&#39;&#39;

  doc = xml.dom.minidom.parseString(data)
  root = doc.documentElement

  for node in root.childNodes:
    if node.nodeName == &#39;skey&#39;:
      skey = node.childNodes[0].data
    elif node.nodeName == &#39;wxsid&#39;:
      wxsid = node.childNodes[0].data
    elif node.nodeName == &#39;wxuin&#39;:
      wxuin = node.childNodes[0].data
    elif node.nodeName == &#39;pass_ticket&#39;:
      pass_ticket = node.childNodes[0].data

  # print &#39;skey: %s, wxsid: %s, wxuin: %s, pass_ticket: %s&#39; % (skey, wxsid, wxuin, pass_ticket)

  if skey == &#39;&#39; or wxsid == &#39;&#39; or wxuin == &#39;&#39; or pass_ticket == &#39;&#39;:
    return False

  BaseRequest = {
    &#39;Uin&#39;: int(wxuin),
    &#39;Sid&#39;: wxsid,
    &#39;Skey&#39;: skey,
    &#39;DeviceID&#39;: deviceId,
  }

  return True


def webwxinit():
  url = base_uri + &#39;/webwxinit?pass_ticket=%s&skey=%s&r=%s&#39; % (pass_ticket, skey, int(time.time()))
  params = {
    &#39;BaseRequest&#39;: BaseRequest
  }

  request = urllib2.Request(url=url, data=json.dumps(params))
  request.add_header(&#39;ContentType&#39;, &#39;application/json; charset=UTF-8&#39;)
  response = urllib2.urlopen(request)
  data = response.read()

  if DEBUG == True:
    f = open(os.getcwd() + &#39;/webwxinit.json&#39;, &#39;wb&#39;)
    f.write(data)
    f.close()

  # print data

  global ContactList, My
  dic = json.loads(data)
  ContactList = dic[&#39;ContactList&#39;]
  My = dic[&#39;User&#39;]

  ErrMsg = dic[&#39;BaseResponse&#39;][&#39;ErrMsg&#39;]
  if len(ErrMsg) > 0:
    print ErrMsg

  Ret = dic[&#39;BaseResponse&#39;][&#39;Ret&#39;]
  if Ret != 0:
    return False

  return True


def webwxgetcontact():
  url = base_uri + &#39;/webwxgetcontact?pass_ticket=%s&skey=%s&r=%s&#39; % (pass_ticket, skey, int(time.time()))

  request = urllib2.Request(url=url)
  request.add_header(&#39;ContentType&#39;, &#39;application/json; charset=UTF-8&#39;)
  response = urllib2.urlopen(request)
  data = response.read()

  if DEBUG == True:
    f = open(os.getcwd() + &#39;/webwxgetcontact.json&#39;, &#39;wb&#39;)
    f.write(data)
    f.close()

  # print data

  dic = json.loads(data)
  MemberList = dic[&#39;MemberList&#39;]

  # 倒序遍历,不然删除的时候出问题..
  SpecialUsers = [&#39;newsapp&#39;, &#39;fmessage&#39;, &#39;filehelper&#39;, &#39;weibo&#39;, &#39;qqmail&#39;, &#39;fmessage&#39;, &#39;tmessage&#39;, &#39;qmessage&#39;,
          &#39;qqsync&#39;, &#39;floatbottle&#39;, &#39;lbsapp&#39;, &#39;shakeapp&#39;, &#39;medianote&#39;, &#39;qqfriend&#39;, &#39;readerapp&#39;, &#39;blogapp&#39;,
          &#39;facebookapp&#39;, &#39;masssendapp&#39;, &#39;meishiapp&#39;, &#39;feedsapp&#39;, &#39;voip&#39;, &#39;blogappweixin&#39;, &#39;weixin&#39;,
          &#39;brandsessionholder&#39;, &#39;weixinreminder&#39;, &#39;wxid_novlwrv3lqwv11&#39;, &#39;gh_22b87fa7cb3c&#39;,
          &#39;officialaccounts&#39;, &#39;notification_messages&#39;, &#39;wxid_novlwrv3lqwv11&#39;, &#39;gh_22b87fa7cb3c&#39;, &#39;wxitil&#39;,
          &#39;userexperience_alarm&#39;, &#39;notification_messages&#39;]
  for i in xrange(len(MemberList) - 1, -1, -1):
    Member = MemberList[i]
    if Member[&#39;VerifyFlag&#39;] & 8 != 0: # 公众号/服务号
      MemberList.remove(Member)
    elif Member[&#39;UserName&#39;] in SpecialUsers: # 特殊账号
      MemberList.remove(Member)
    elif Member[&#39;UserName&#39;].find(&#39;@@&#39;) != -1: # 群聊
      MemberList.remove(Member)
    elif Member[&#39;UserName&#39;] == My[&#39;UserName&#39;]: # 自己
      MemberList.remove(Member)

  return MemberList


def createChatroom(UserNames):
  MemberList = []
  for UserName in UserNames:
    MemberList.append({&#39;UserName&#39;: UserName})

  url = base_uri + &#39;/webwxcreatechatroom?pass_ticket=%s&r=%s&#39; % (pass_ticket, int(time.time()))
  params = {
    &#39;BaseRequest&#39;: BaseRequest,
    &#39;MemberCount&#39;: len(MemberList),
    &#39;MemberList&#39;: MemberList,
    &#39;Topic&#39;: &#39;&#39;,
  }

  request = urllib2.Request(url=url, data=json.dumps(params))
  request.add_header(&#39;ContentType&#39;, &#39;application/json; charset=UTF-8&#39;)
  response = urllib2.urlopen(request)
  data = response.read()

  # print data

  dic = json.loads(data)
  ChatRoomName = dic[&#39;ChatRoomName&#39;]
  MemberList = dic[&#39;MemberList&#39;]
  DeletedList = []
  for Member in MemberList:
    if Member[&#39;MemberStatus&#39;] == 4: # 被对方删除了
      DeletedList.append(Member[&#39;UserName&#39;])

  ErrMsg = dic[&#39;BaseResponse&#39;][&#39;ErrMsg&#39;]
  if len(ErrMsg) > 0:
    print ErrMsg

  return (ChatRoomName, DeletedList)


def deleteMember(ChatRoomName, UserNames):
  url = base_uri + &#39;/webwxupdatechatroom?fun=delmember&pass_ticket=%s&#39; % (pass_ticket)
  params = {
    &#39;BaseRequest&#39;: BaseRequest,
    &#39;ChatRoomName&#39;: ChatRoomName,
    &#39;DelMemberList&#39;: &#39;,&#39;.join(UserNames),
  }

  request = urllib2.Request(url=url, data=json.dumps(params))
  request.add_header(&#39;ContentType&#39;, &#39;application/json; charset=UTF-8&#39;)
  response = urllib2.urlopen(request)
  data = response.read()

  # print data

  dic = json.loads(data)
  ErrMsg = dic[&#39;BaseResponse&#39;][&#39;ErrMsg&#39;]
  if len(ErrMsg) > 0:
    print ErrMsg

  Ret = dic[&#39;BaseResponse&#39;][&#39;Ret&#39;]
  if Ret != 0:
    return False

  return True


def addMember(ChatRoomName, UserNames):
  url = base_uri + &#39;/webwxupdatechatroom?fun=addmember&pass_ticket=%s&#39; % (pass_ticket)
  params = {
    &#39;BaseRequest&#39;: BaseRequest,
    &#39;ChatRoomName&#39;: ChatRoomName,
    &#39;AddMemberList&#39;: &#39;,&#39;.join(UserNames),
  }

  request = urllib2.Request(url=url, data=json.dumps(params))
  request.add_header(&#39;ContentType&#39;, &#39;application/json; charset=UTF-8&#39;)
  response = urllib2.urlopen(request)
  data = response.read()

  # print data

  dic = json.loads(data)
  MemberList = dic[&#39;MemberList&#39;]
  DeletedList = []
  for Member in MemberList:
    if Member[&#39;MemberStatus&#39;] == 4: # 被对方删除了
      DeletedList.append(Member[&#39;UserName&#39;])

  ErrMsg = dic[&#39;BaseResponse&#39;][&#39;ErrMsg&#39;]
  if len(ErrMsg) > 0:
    print ErrMsg

  return DeletedList


def main():
  opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(cookielib.CookieJar()))
  urllib2.install_opener(opener)

  if getUUID() == False:
    print &#39;获取uuid失败&#39;
    return

  showQRImage()
  time.sleep(1)

  while waitForLogin() != &#39;200&#39;:
    pass

  os.remove(QRImagePath)

  if login() == False:
    print &#39;登录失败&#39;
    return

  if webwxinit() == False:
    print &#39;初始化失败&#39;
    return

  MemberList = webwxgetcontact()

  MemberCount = len(MemberList)
  print &#39;通讯录共%s位好友&#39; % MemberCount

  ChatRoomName = &#39;&#39;
  result = []
  for i in xrange(0, int(math.ceil(MemberCount / float(MAX_GROUP_NUM)))):
    UserNames = []
    NickNames = []
    DeletedList = &#39;&#39;
    for j in xrange(0, MAX_GROUP_NUM):
      if i * MAX_GROUP_NUM + j >= MemberCount:
        break

      Member = MemberList[i * MAX_GROUP_NUM + j]
      UserNames.append(Member[&#39;UserName&#39;])
      NickNames.append(Member[&#39;NickName&#39;].encode(&#39;utf-8&#39;))

    print &#39;第%s组...&#39; % (i + 1)
    print &#39;, &#39;.join(NickNames)
    print &#39;回车键继续...&#39;
    raw_input()

    # 新建群组/添加成员
    if ChatRoomName == &#39;&#39;:
      (ChatRoomName, DeletedList) = createChatroom(UserNames)
    else:
      DeletedList = addMember(ChatRoomName, UserNames)

    DeletedCount = len(DeletedList)
    if DeletedCount > 0:
      result += DeletedList

    print &#39;找到%s个被删好友&#39; % DeletedCount
    # raw_input()

    # 删除成员
    deleteMember(ChatRoomName, UserNames)

  # todo 删除群组


  resultNames = []
  for Member in MemberList:
    if Member[&#39;UserName&#39;] in result:
      NickName = Member[&#39;NickName&#39;]
      if Member[&#39;RemarkName&#39;] != &#39;&#39;:
        NickName += &#39;(%s)&#39; % Member[&#39;RemarkName&#39;]
      resultNames.append(NickName.encode(&#39;utf-8&#39;))

  print &#39;---------- 被删除的好友列表 ----------&#39;
  print &#39;\n&#39;.join(resultNames)
  print &#39;-----------------------------------&#39;


# windows下编码问题修复
class UnicodeStreamFilter:
  def __init__(self, target):
    self.target = target
    self.encoding = &#39;utf-8&#39;
    self.errors = &#39;replace&#39;
    self.encode_to = self.target.encoding

  def write(self, s):
    if type(s) == str:
      s = s.decode(&#39;utf-8&#39;)
    s = s.encode(self.encode_to, self.errors).decode(self.encode_to)
    self.target.write(s)


if sys.stdout.encoding == &#39;cp936&#39;:
  sys.stdout = UnicodeStreamFilter(sys.stdout)

if __name__ == &#39;__main__&#39;:
  print &#39;本程序的查询结果可能会引起一些心理上的不适,请小心使用...&#39;
  print &#39;回车键继续...&#39;
  raw_input()

  main()

  print &#39;回车键结束&#39;
  raw_input()
登录后复制

以上就是python查看微信好友是否删除自己的内容,更多相关内容请关注PHP中文网(www.php.cn)!


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何利用Debian Apache日志提升网站性能 如何利用Debian Apache日志提升网站性能 Apr 12, 2025 pm 11:36 PM

本文将阐述如何通过分析Debian系统下的Apache日志来提升网站性能。一、日志分析基础Apache日志记录了所有HTTP请求的详细信息,包括IP地址、时间戳、请求URL、HTTP方法和响应代码等。在Debian系统中,这些日志通常位于/var/log/apache2/access.log和/var/log/apache2/error.log目录下。理解日志结构是有效分析的第一步。二、日志分析工具您可以使用多种工具分析Apache日志:命令行工具:grep、awk、sed等命令行工具可

Python:游戏,Guis等 Python:游戏,Guis等 Apr 13, 2025 am 12:14 AM

Python在游戏和GUI开发中表现出色。1)游戏开发使用Pygame,提供绘图、音频等功能,适合创建2D游戏。2)GUI开发可选择Tkinter或PyQt,Tkinter简单易用,PyQt功能丰富,适合专业开发。

PHP和Python:比较两种流行的编程语言 PHP和Python:比较两种流行的编程语言 Apr 14, 2025 am 12:13 AM

PHP和Python各有优势,选择依据项目需求。1.PHP适合web开发,尤其快速开发和维护网站。2.Python适用于数据科学、机器学习和人工智能,语法简洁,适合初学者。

Debian Sniffer在DDoS攻击检测中的作用 Debian Sniffer在DDoS攻击检测中的作用 Apr 12, 2025 pm 10:42 PM

本文探讨DDoS攻击检测方法,虽然未找到“DebianSniffer”的直接应用案例,但以下方法可用于DDoS攻击检测:有效的DDoS攻击检测技术:基于流量分析的检测:通过监控网络流量的异常模式,例如突发性的流量增长、特定端口的连接数激增等,来识别DDoS攻击。这可以使用多种工具实现,包括但不限于专业的网络监控系统和自定义脚本。例如,Python脚本结合pyshark和colorama库可以实时监控网络流量并发出警报。基于统计分析的检测:通过分析网络流量的统计特征,例如数据

Nginx SSL证书更新Debian教程 Nginx SSL证书更新Debian教程 Apr 13, 2025 am 07:21 AM

本文将指导您如何在Debian系统上更新NginxSSL证书。第一步:安装Certbot首先,请确保您的系统已安装certbot和python3-certbot-nginx包。若未安装,请执行以下命令:sudoapt-getupdatesudoapt-getinstallcertbotpython3-certbot-nginx第二步:获取并配置证书使用certbot命令获取Let'sEncrypt证书并配置Nginx:sudocertbot--nginx按照提示选

debian readdir如何与其他工具集成 debian readdir如何与其他工具集成 Apr 13, 2025 am 09:42 AM

Debian系统中的readdir函数是用于读取目录内容的系统调用,常用于C语言编程。本文将介绍如何将readdir与其他工具集成,以增强其功能。方法一:C语言程序与管道结合首先,编写一个C程序调用readdir函数并输出结果:#include#include#includeintmain(intargc,char*argv[]){DIR*dir;structdirent*entry;if(argc!=2){

Python和时间:充分利用您的学习时间 Python和时间:充分利用您的学习时间 Apr 14, 2025 am 12:02 AM

要在有限的时间内最大化学习Python的效率,可以使用Python的datetime、time和schedule模块。1.datetime模块用于记录和规划学习时间。2.time模块帮助设置学习和休息时间。3.schedule模块自动化安排每周学习任务。

Debian OpenSSL如何配置HTTPS服务器 Debian OpenSSL如何配置HTTPS服务器 Apr 13, 2025 am 11:03 AM

在Debian系统上配置HTTPS服务器涉及几个步骤,包括安装必要的软件、生成SSL证书、配置Web服务器(如Apache或Nginx)以使用SSL证书。以下是一个基本的指南,假设你使用的是ApacheWeb服务器。1.安装必要的软件首先,确保你的系统是最新的,并安装Apache和OpenSSL:sudoaptupdatesudoaptupgradesudoaptinsta

See all articles