侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Python爬取qq空间说说的实例代码

Python  /  管理员 发布于 7年前   258

具体代码如下所示:

#coding:utf-8#!/usr/bin/python3from selenium import webdriverimport timeimport reimport importlib2import sysimportlib2.reload(sys)def startSpider():  driver = webdriver.Chrome('/Users/zachary/zachary/chromedriver.exe') #这个是chormedriver的地址  driver.get('https://qzone.qq.com/')  driver.switch_to.frame('login_frame')  driver.find_element_by_id('switcher_plogin').click()  driver.find_element_by_id('u').clear()  driver.find_element_by_id('u').send_keys('QQ号') #这里填写你的QQ号  driver.find_element_by_id('p').clear()  driver.find_element_by_id('p').send_keys('QQ密码') #这里填写你的QQ密码  driver.find_element_by_id('login_button').click()  time.sleep(2)  #设置爬取内容保存路径  f = open('/Users/zachary/Documents/shuoshuo.txt','w')  #---------------获得g_qzonetoken 和 gtk  html = driver.page_source  '''g_qzonetoken=re.search('window\.g_qzonetoken = \(function\(\)\{ try\{return (.*?);\} catch\(e\)',html)#从网页源码中提取g_qzonetoken'''  g_qzonetoken = "e794139a284d6ea9e0b26826e541b55df37d0667a3544f534de25aebdb64628d3ab75e1d7104bbb22a"  cookie = {}#初始化cookie字典  for elem in driver.get_cookies():#取cookies    cookie[elem['name']] = elem['value']  gtk=getGTK(cookie)#通过getGTK函数计算gtk  #print(g_qzonetoken)  #print(gtk)  #--------------获得好友列表  注意下面的链接  driver.get('https://user.qzone.qq.com/proxy/domain/r.qzone.qq.com/cgi-bin/tfriend/friend_hat_get.cgi?hat_seed=1&uin=你的QQ号fupdate=1&g_tk='+str(gtk)+'&qzonetoken='+str(g_qzonetoken)+'&g_tk='+str(gtk))  friend_list = driver.page_source  friend_list = str( friend_list )  abtract_pattern = re.compile('\"(.\d*)\":\{\\n"realname":"(.*?)"}',re.S)  QQ_name_list = re.findall(abtract_pattern,str(friend_list)) #数组  print(QQ_name_list)  numList=dict()# numList => (QQnum:QQname) #列表  for i in QQ_name_list:    numList[str(i[0])]=str(i[1])  begin = 0  last_source = ""  tag = 1  first = 0  firstTime=""  #如果要爬取自己的说说,手动添加自己的qq号  #numList['你的qq号']='你的名字'  #print(numList)  for key in numList.keys():    QQnum = key    QQname = numList[QQnum]    if QQnum == "好友qq号": #根据qq号查找指定好友说说      count = 1      begin = 0      while tag==1 :        #-------------进入好友说说页面#'+QQnum+'       '+str(begin)+'        #print("Begin:"+str(begin))        driver.get('https://user.qzone.qq.com/proxy/domain/taotao.qq.com/cgi-bin/emotion_cgi_msglist_v6?uin='+QQnum+'&ftype=0&sort=0&pos='+str(begin)+'&num=40&replynum=200&g_tk='+str(gtk)+'&callback=_preloadCallback&code_version=1&format=jsonp&need_private_comment=1&qzonetoken='+str(g_qzonetoken)+'&g_tk='+str(gtk))        try:          msg_list_json = driver.page_source        except:          begin = begin + 40          continue        msg_list_json = str(msg_list_json)        if last_source==msg_list_json :          break        else:          last_source=msg_list_json        #检测是否没有权限访问        abtract_pattern = re.compile(',"message":"(.*?)","name":',re.S)        message = re.findall(abtract_pattern,str(msg_list_json))        if message!=[]:          if str(message[0])=='对不起,主人设置了保密,您没有权限查看':#对不起,主人设置了保密,您没有权限查看break        #print(msg_list_json)        #解析JSON        #webDriver没有现成的JSON解析器,所以采用获取源码的方式,然后使用正则表达式获取具体细节        msg_list_json = msg_list_json.split("msglist")[1]#拆分json,缩小范围,也能加快解析速度        msg_list_json = msg_list_json.split("smoothpolicy")[0]        msg_list_json = msg_list_json.split("commentlist")[1:]        #说说动态分4种:1、文字说说(或带有配图的文字说说)        #       2、只有图片的说说        #       3、转发,并配有文字        #       4、转发,不配文字        for text in msg_list_json:          # 1、先检查说说,用户是否发送了文字,如果没有文字,正则表达式匹配无效          abtract_pattern = re.compile('\}\],"content":"(.*?)","createTime":"(.*?)","created_time":(.*?),"',re.S)          msg_time = re.findall(abtract_pattern,str(text))          if msg_time!=[]:# 2、如果作者说说有文字,那么检查是否有转发内容msg = str(msg_time[0][0])sendTime = str(msg_time[0][1])abtract_pattern = re.compile('\}\],"content":"(.*?)"},"rt_createTime":"(.*?)","',re.S)text = text.split("created_time")[1]msg_time2 = re.findall(abtract_pattern,str(text))#合并发送内容 格式:评论+转发内容if msg_time2!=[]:  msg = msg +" 转发内容:"+str(msg_time2[0][0])          else:# 3、说说内容为空,检查是否为 =>只有图片的说说 or 转发,不配文字#获取正文发送时间 (发送时间分为:正文发送时间 or 转发时间)abtract_pattern = re.compile('"conlist":null,"content":"","createTime":"(.*?)",',re.S)msgNull_time = re.findall(abtract_pattern,str(text))if msgNull_time!=[]:  #如果有正文发送时间,那么就是这条说说仅含有图片 =>只有图片的说说  msg = "图片"  sendTime = str(msgNull_time[0])else:  #如果没有正文发送时间,那么就是说这条说为 =>转发,不配文字  abtract_pattern = re.compile('\}\],"content":"(.*?)"},"rt_createTime":"(.*?)","',re.S)  msg_time = re.findall(abtract_pattern,str(text))  msg =" 转发内容:"+str(msg_time[0][0])  sendTime = str(msg_time[0][1])          #写入本地文件          #f.write('{},{},{},{}\n'.format(str(QQname),str(QQnum),sendTime,msg))          print(str(count)+" : "+str(QQname)+" : "+str(QQnum)+" : "+sendTime+" : "+msg)          count = count + 1        begin = begin + 40def getGTK(cookie):  hashes = 5381  for letter in cookie['p_skey']:    hashes += (hashes << 5) + ord(letter)  return hashes & 0x7fffffffstartSpider()print("爬取结束")

总结

以上所述是小编给大家介绍的Python爬取qq空间说说的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对站的支持!


  • 上一条:
    python3 flask实现文件上传功能
    下一条:
    python读取Excel实例详解
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客