亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發(fā) > PHP > 正文

php實(shí)現(xiàn)爬取和分析知乎用戶數(shù)據(jù)

2024-05-04 23:42:35
字體:
供稿:網(wǎng)友
本文給大家介紹的是利用php的curl編寫的爬取知乎用戶數(shù)據(jù)的爬蟲,并分析用戶的各種屬性,有需要的小伙伴可以參考下
 

背景說明:小拽利用php的curl寫的爬蟲,實(shí)驗(yàn)性的爬取了知乎5w用戶的基本信息;同時,針對爬取的數(shù)據(jù),進(jìn)行了簡單的分析呈現(xiàn)。

php的spider代碼和用戶dashboard的展現(xiàn)代碼,整理后上傳github,在個人博客和公眾號更新代碼庫,程序僅供娛樂和學(xué)習(xí)交流;如果有侵犯知乎相關(guān)權(quán)益,請盡快聯(lián)系本人刪除。

無圖無真相

移動端分析數(shù)據(jù)截圖

php實(shí)現(xiàn)爬取和分析知乎用戶數(shù)據(jù)

pc端分析數(shù)據(jù)截圖

php實(shí)現(xiàn)爬取和分析知乎用戶數(shù)據(jù)

整個爬取,分析,展現(xiàn)過程大概分如下幾步,小拽將分別介紹

  1. curl爬取知乎網(wǎng)頁數(shù)據(jù)
  2. 正則分析知乎網(wǎng)頁數(shù)據(jù)
  3. 數(shù)據(jù)數(shù)據(jù)入庫和程序部署
  4. 數(shù)據(jù)分析和呈現(xiàn)

curl爬取網(wǎng)頁數(shù)據(jù)

PHP的curl擴(kuò)展是PHP支持的,允許你與各種服務(wù)器使用各種類型的協(xié)議進(jìn)行連接和通信的庫。是一個非常便捷的抓取網(wǎng)頁的工具,同時,支持多線程擴(kuò)展。

本程序抓取的是知乎對外提供用戶訪問的個人信息頁面https://www.zhihu.com/people/xxx,抓取過程需要攜帶用戶cookie才能獲取頁面。直接上碼

獲取頁面cookie

 

復(fù)制代碼代碼如下:

// 登錄知乎,打開個人中心,打開控制臺,獲取cookie
document.cookie
"_za=67254197-3wwb8d-43f6-94f0-fb0e2d521c31; _ga=GA1.2.2142818188.1433767929; q_c1=78ee1604225d47d08cddd8142a08288b23|1452172601000|1452172601000; _xsrf=15f0639cbe6fb607560c075269064393; cap_id="N2QwMTExNGQ0YTY2NGVddlMGIyNmQ4NjdjOTU0YTM5MmQ=|1453444256|49fdc6b43dc51f702b7d6575451e228f56cdaf5d"; __utmt=1; unlock_ticket="QUJDTWpmM0lsZdd2dYQUFBQVlRSlZUVTNVb1ZaNDVoQXJlblVmWGJ0WGwyaHlDdVdscXdZU1VRPT0=|1453444421|c47a2afde1ff334d416bafb1cc267b41014c9d5f"; __utma=51854390.21428dd18188.1433767929.1453187421.1453444257.3; __utmb=51854390.14.8.1453444425011; __utmc=51854390; __utmz=51854390.1452846679.1.dd1.utmcsr=google|utmccn=(organic)|utmcmd=organic|utmctr=(not%20provided); __utmv=51854390.100-1|2=registration_date=20150823=1^dd3=entry_date=20150823=1"

 

抓取個人中心頁面

通過curl,攜帶cookie,先抓取本人中心頁面

/** * 通過用戶名抓取個人中心頁面并存儲 *  * @param $username str :用戶名 flag * @return boolean   :成功與否標(biāo)志 */public function spiderUser($username){  $cookie = "xxxx" ;  $url_info = 'http://www.zhihu.com/people/' . $username; //此處cui-xiao-zhuai代表用戶ID,可以直接看url獲取本人id  $ch = curl_init($url_info); //初始化會話  curl_setopt($ch, CURLOPT_HEADER, 0);  curl_setopt($ch, CURLOPT_COOKIE, $cookie); //設(shè)置請求COOKIE  curl_setopt($ch, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']);  curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //將curl_exec()獲取的信息以文件流的形式返回,而不是直接輸出。  curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);  $result = curl_exec($ch);   file_put_contents('/home/work/zxdata_ch/php/zhihu_spider/file/'.$username.'.html',$result);   return true; }

正則分析網(wǎng)頁數(shù)據(jù)分析新鏈接,進(jìn)一步爬取

對于抓取過來的網(wǎng)頁進(jìn)行存儲,要想進(jìn)行進(jìn)一步的爬取,頁面必須包含有可用于進(jìn)一步爬取用戶的鏈接。通過對知乎頁面分析發(fā)現(xiàn):在個人中心頁面中有關(guān)注人和部分點(diǎn)贊人和被關(guān)注人。
如下所示

 

復(fù)制代碼代碼如下:

// 抓取的html頁面中發(fā)現(xiàn)了新的用戶,可用于爬蟲
<a class="zm-item-link-avatar avatar-link" href="/people/new-user" data-tip="p$t$new-user">

 

ok,這樣子就可以通過自己-》關(guān)注人-》關(guān)注人的關(guān)注人-》。。。進(jìn)行不斷爬取。接下來就是通過正則匹配提取該信息

 

復(fù)制代碼代碼如下:

// 匹配到抓取頁面的所有用戶
preg_match_all('///people//([/w-]+)/"/i', $str, $match_arr);
// 去重合并入新的用戶數(shù)組,用戶進(jìn)一步抓取
self::$newUserArr = array_unique(array_merge($match_arr[1], self::$newUserArr));

 

到此,整個爬蟲過程就可以順利進(jìn)行了。
如果需要大量的抓取數(shù)據(jù),可以研究下curl_multipcntl進(jìn)行多線程的快速抓取,此處不做贅述。

分析用戶數(shù)據(jù),提供分析

通過正則可以進(jìn)一步匹配出更多的該用戶數(shù)據(jù),直接上碼。

// 獲取用戶頭像preg_match('/<img.+src=/"?([^/s]+/.(jpg|gif|bmp|bnp|png))/"?.+>/i', $str, $match_img);$img_url = $match_img[1];// 匹配用戶名:// <span class="name">崔小拽</span>preg_match('/<span.+class=/"?name/"?>([/x{4e00}-/x{9fa5}]+).+span>/u', $str, $match_name);$user_name = $match_name[1];// 匹配用戶簡介// class bio span 中文preg_match('/<span.+class=/"?bio/"?.+/>([/x{4e00}-/x{9fa5}]+).+span>/u', $str, $match_title);$user_title = $match_title[1];// 匹配性別//<input type="radio" name="gender" value="1" checked="checked" class="male"/> 男  // gender value1 ;結(jié)束 中文preg_match('/<input.+name=/"?gender/"?.+value=/"?1/"?.+([/x{4e00}-/x{9fa5}]+).+/;/u', $str, $match_sex);$user_sex = $match_sex[1];// 匹配地區(qū)//<span class="location item" style="margin: 0px; padding: 0px; width: 660px; overflow: hidden; clear: both;">		
# 官方的最優(yōu)批量插入INSERT INTO yourtable VALUES (1,2), (5,5), ...;

部署操作。程序在抓取過程中,有可能會出現(xiàn)異常掛掉,為了保證高效穩(wěn)定,盡可能的寫一個定時腳本。每隔一段時間干掉,重新跑,這樣即使異常掛掉也不會浪費(fèi)太多寶貴時間,畢竟,time is money。

#!/bin/bash# 干掉ps aux |grep spider |awk '{print $2}'|xargs kill -9sleep 5s# 重新跑nohup /home/cuixiaohuan/lamp/php5/bin/php /home/cuixiaohuan/php/zhihu_spider/spider_new.php &  

數(shù)據(jù)分析呈現(xiàn)

數(shù)據(jù)的呈現(xiàn)主要使用echarts 3.0,感覺對于移動端兼容還不錯。兼容移動端的頁面響應(yīng)式布局主要通過幾個簡單的css控制,代碼如下

// 獲取用戶頭像preg_match('/<img.+src=/"?([^/s]+/.(jpg|gif|bmp|bnp|png))/"?.+>/i', $str, $match_img);$img_url = $match_img[1];// 匹配用戶名:// <span class="name">崔小拽</span>preg_match('/<span.+class=/"?name/"?>([/x{4e00}-/x{9fa5}]+).+span>/u', $str, $match_name);$user_name = $match_name[1];// 匹配用戶簡介// class bio span 中文preg_match('/<span.+class=/"?bio/"?.+/>([/x{4e00}-/x{9fa5}]+).+span>/u', $str, $match_title);$user_title = $match_title[1];// 匹配性別//<input type="radio" name="gender" value="1" checked="checked" class="male"/> 男  // gender value1 ;結(jié)束 中文preg_match('/<input.+name=/"?gender/"?.+value=/"?1/"?.+([/x{4e00}-/x{9fa5}]+).+/;/u', $str, $match_sex);$user_sex = $match_sex[1];// 匹配地區(qū)//<span class="location item" title="北京">preg_match('/<span.+class=/"?location.+/"?.+/"([/x{4e00}-/x{9fa5}]+)/">/u', $str, $match_city);$user_city = $match_city[1];// 匹配工作//<span class="employment item" title="人見人罵的公司">人見人罵的公司</span>preg_match('/<span.+class=/"?employment.+/"?.+/"([/x{4e00}-/x{9fa5}]+)/">/u', $str, $match_employment);$user_employ = $match_employment[1];// 匹配職位// <span class="position item" title="程序猿"><a href="/topic/19590046" title="程序猿" class="topic-link" data-token="19590046" data-topicid="13253">程序猿</a></span>preg_match('/<span.+class=/"?position.+/"?.+/"([/x{4e00}-/x{9fa5}]+).+/">/u', $str, $match_position);$user_position = $match_position[1];// 匹配學(xué)歷// <span class="education item" title="研究僧">研究僧</span>preg_match('/<span.+class=/"?education.+/"?.+/"([/x{4e00}-/x{9fa5}]+)/">/u', $str, $match_education);$user_education = $match_education[1];// 工作情況// <span class="education-extra item" title='挨踢'>挨踢</span>preg_match('/<span.+class=/"?education-extra.+/"?.+>([/x{4e00}-/x{9fa5}]+)</u', $str, $match_education_extra);$user_education_extra = $match_education_extra[1];// 匹配關(guān)注話題數(shù)量// class="zg-link-litblue"><strong>41 個話題</strong></a>preg_match('/class=/"?zg-link-litblue/"?><strong>(/d+)/s.+strong>/i', $str, $match_topic);$user_topic = $match_topic[1];// 關(guān)注人數(shù)// <span class="zg-gray-normal">關(guān)注了preg_match_all('/<strong>(/d+)<.+<label>/i', $str, $match_care);$user_care = $match_care[1][0];$user_be_careed = $match_care[1][1];// 歷史瀏覽量// <span class="zg-gray-normal">個人主頁被 <strong>17</strong> 人瀏覽</span>preg_match('/class=/"?zg-gray-normal/"?.+>(/d+)<.+span>/i', $str, $match_browse);$user_browse = $match_browse[1];

不足和待學(xué)習(xí)

整個過程中涉及php,shell,js,css,html,正則等語言和部署等基礎(chǔ)知識,但還有諸多需要改進(jìn)完善,小拽特此記錄,后續(xù)補(bǔ)充例:

  1. php 采用multicul進(jìn)行多線程。
  2. 正則匹配進(jìn)一步優(yōu)化
  3. 部署和抓取過程采用redis提升存儲
  4. 移動端布局的兼容性提升
  5. js的模塊化和sass書寫css。


注:相關(guān)教程知識閱讀請移步到PHP教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国产精品91xxx| 欧美成人午夜电影| 日本黄色播放器| 欧美精品第1页| 国产欧美一级| 亚洲国产乱码最新视频| 中文av一区二区| 蜜桃视频欧美| 2021av天天| 91精品国自产在线| 国产精品一区二区三区成人| 91久久大香伊蕉在人线| 另类视频在线观看+1080p| 欧美日韩国产色视频| 一区二区免费| 亚洲欧美制服另类日韩| 一区二区欧美国产| 亚洲综合av网| 日韩欧美国产三级电影视频| 在线观看国产视频| 日本天堂在线| 久久久.com| 日本特黄a级高清免费大片| 久久精品国产亚洲高清剧情介绍| 欧美精品乱人伦久久久久久| 欧美成人首页| 丝袜足控免费网站xx网站| 在线日韩一区二区| 男男gay免费网站| 国产成人在线电影| 亚洲一区美女视频在线观看免费| 久久久久久亚洲中文字幕无码| 成人在线一区二区| 欧美成人三级在线| 日韩精品一区二区在线视频| 中文字幕三级电影| 欧美日本黄视频| 播九公社成人综合网站| 亚洲久本草在线中文字幕| 欧美劲爆第一页| 97久久精品人人爽人人爽蜜臀| 国产精品一区二区免费看| 国产无精乱码一区二区三区| 最近中文字幕mv2018在线高清| av不卡在线免费观看| 亚洲精品中文字幕乱码三区| 性欧美hd调教| 亚洲AV无码一区二区三区少妇| 高清精品久久| 亚洲老头老太hd| 欧美性大战久久久久xxx| 日韩精品成人一区二区三区| 亚洲精品小视频在线观看| 久久亚洲国产成人精品性色| 欧美亚洲精品一区| 欧美老女人在线视频| 亚洲精品免费av| 国产一区二区福利视频| 最近中文av字幕在线中文| 天天干天天操天天玩| 国产内射老熟女aaaa∵| 欧美日本在线| 欧美一级电影免费在线观看| 国产精彩视频在线| 精品国产一二三区| 久久精品国产999大香线蕉| 国产极品美女高潮无套久久久| 在线视频亚洲一区| 日韩一区中文| 日韩在线视频国产| 老司机精品影院| 国产精品久久久久久久岛一牛影视| 免费观看a级片| 91麻豆精品国产91久久综合| 亚洲综合色在线观看| 久久综合久久鬼| 国产老女人精品毛片久久| 午夜电影网亚洲视频| 亚洲mv在线看| 国内精品区一区二区三| 极品美乳网红视频免费在线观看| 久久精品噜噜噜成人av农村| 久草亚洲一区| 色播五月综合| 人人澡人人澡人人看| 国产91精品免费| 亚洲地区一二三色| 久久久之久亚州精品露出| 欧美a极品极品欧美| 久久久电影一区二区三区| 国产高清免费在线观看| 丝袜脚交免费网站xx| 久久精品天堂| 欧美精品九九99久久| 国产精品视频黄色| 麻豆网站在线看| 国产精品欧美一级免费| 久久久国产精品视频| 中文字幕亚洲乱码| 亚洲一区一卡| 国产乱人乱偷精品视频a人人澡| 超碰精品一区二区三区乱码| 一区二区三区亚洲变态调教大结局| 99久久免费视频.com| 少妇av一区二区三区无码| 最新国产精品精品视频| 亚洲高清视频免费观看| 亚洲国产欧美日韩另类综合| 精品在线亚洲视频| 天天综合网网欲色| 最新视频 - x88av| 日韩欧美一区视频| 国产精成人品localhost| 97人人干人人| 超碰在线网站| 91久久久久久久久久久久久| 免费在线观看的毛片| 麻豆国产va免费精品高清在线| 国产成人精品视频免费看| 久久久久久色| 国产一级片免费在线观看| 韩国19禁主播vip福利视频| 日韩在线观看你懂的| 久久久人成影片免费观看| 亚洲最大av网站| 免费特级黄色片| 免费黄网站观看| 成人黄色在线看| 久久精品午夜福利| 日本黄色激情视频| av日韩国产| 欧美视频四区| 屁屁影院ccyy国产第一页| 国产youjizz在线| 国产成人福利视频| 精品国产亚洲一区二区在线观看| 天码人妻一区二区三区在线看| 国产成人77亚洲精品www| 亚洲丝袜一区| 中文字幕日韩精品无码内射| 午夜激情福利电影| 91精品国产免费久久久久久| 日韩成人综合网站| 牛夜精品久久久久久久| 欧美亚洲动漫精品| 青青国产在线视频| 黑色丝袜福利片av久久| 亚洲精品va| 成入视频在线观看| 久久aⅴ国产紧身牛仔裤| 亚洲片在线资源| 亚洲国产123| 国产呻吟对白刺激无套视频在线| 中文网丁香综合网| 欧美天堂一区二区三区| 乱插在线www| 国产精品丝袜久久久久久高清| 中文字幕 亚洲视频| 自拍偷拍电影| 国产日韩欧美精品一区二区三区| 亚洲少妇屁股交4| 久久国产精品波多野结衣av| 蜜桃999成人看片在线观看| 亚洲天堂精品在线观看| 男女啪啪无遮挡| 国产免费一区二区三区在线观看| 亚洲成人黄色网址| 99视频只有精品| 一本色道久久精品| 亚洲国产精品无码观看久久| 中文字幕久久网| 成人欧美视频在线观看播放| 欧美 日韩 成人| 午夜视频久久久| 亚洲午夜久久久久久久久久久| 亚洲精品一品区二品区三品区| 91麻豆精品国产自产在线观看一区| 日本韩国欧美在线| 国产精品xxx| 国产精品视频免费播放| 99久久99九九99九九九| 久久久xxx| 久操成人av| 久久精品九色| 精品亚洲一区二区三区四区| 亚洲一区二区三区四区在线播放| 人妖粗暴刺激videos呻吟| 欧美男女视频| 精品乱子伦一区二区| 精品国产丝袜高跟鞋| 免费看毛片网站| 日本黄色录像片| 黄色片视频在线免费观看| 中文字幕一区二区三区在线乱码| 中文字幕免费视频观看| 日韩网址在线观看| 免费白白视频| 色乱码一区二区三在线看| 中文字幕第17页| 欧美一区二区三级| 一道本成人在线| 久久久久亚洲无码| 欧美xxx久久| 国产精品成人在线视频| 久久久精品人妻无码专区| 在线视频三级| 欧美18—19sex性hd| 色乱码一区二区三区88| 国产高清成人在线| 蜜桃导航-精品导航| 欧美成人一区二区| 精彩国产在线| 亚洲第一页在线观看| 国产一区二区黑人欧美xxxx| 亚洲视频色图| 国产成人精品亚洲男人的天堂| 精品免费一区二区三区蜜桃| 视频免费在线看| 日韩av一二区| 中文字幕av在线播放| 日韩一级性生活片| 在线看a视频| 欧美一区少妇| 四虎国产精品永久在线国在线| 午夜爽爽爽男女免费观看影院| 911精品产国品一二三产区| 欧美a极品极品欧美| 天天综合网日韩| 无套内谢丰满少妇中文字幕| 中文字幕在线免费不卡| 国产视频每日更新| 松下纱荣子在线观看| 天堂精品久久久久| 久久久久久天堂| 国产精品国产高清国产| 国产亲近乱来精品视频| 白丝美女让我捅| 国产欧美久久一区二区| 欧美激情五月| 欧美疯狂爱爱xxxxbbbb| 国产裸体无遮挡| 91一区二区在线观看| 你懂的在线看| 久草视频观看| 欧美黑人xxxxx性受| 黄色小说综合网站| av大全在线| 美国成人毛片| 中文在线观看免费视频| 亚洲国产精品va| 国产青春久久久国产毛片| 欧美激情亚洲精品| 欧洲永久精品大片ww免费漫画| 精品视频偷偷看在线观看| 综合av第一页| 免费毛片在线播放免费| 日韩香蕉视频| 2019av中文字幕| 一本大道久久a久久精品| 欧美aaa大片| 96pao国产成视频永久免费| 欧美不卡在线播放| 中国麻豆视频| 97netav| 亚洲不卡一卡2卡三卡4卡5卡精品| 亚洲精品天天看| 精品一区av| 日韩中文字幕在线视频观看| 欧美黄视频在线观看| 在线午夜精品自拍| 无码人妻aⅴ一区二区三区玉蒲团| 国产成人福利网站| av超碰在线观看| 久久久久久久久久久久久夜| www.色播.com| 狂野欧美激情性xxxx欧美| 羞羞影院体验区| 黄色免费网站在线观看| 国产精品免费在线播放| 国产成人夜间影院在线观看| 欧美一区二区免费| 欧美黄网在线观看| 国产精品一区二区久久| 六月丁香激情综合| 超碰97免费在线| 夜夜嗨av一区二区三区网站四季av| 久久综合九色综合网站| 国产另类自拍| 欧美日韩精品一二三区| 日韩成人激情在线| aaa级黄色片| 日韩av观看网址| 好看的亚洲午夜视频在线| 亚洲一一在线| 一二三四区在线| 国产野外战在线播放| jizzjizz韩国| 日本精品一区二区三区视频| 国内精品久久久久久久| 男人天堂视频在线| 波多野结衣毛片| 综合激情在线| 97在线视频免费看| 国产成人+综合亚洲+天堂| 日韩精品久久久久久福利| 久久www免费人成精品| 欧美日韩免费一区二区三区视频| 久久久久久久少妇| 中文天堂在线观看| 日本三级久久| 狠狠久久亚洲欧美专区| 天天综合在线观看| 国产剧情av在线| 精品一区二区三区中文字幕视频| 日本高清视频在线观看| 视频在线观看99| 超碰在线观看99| 九九视频精品在线| jizz亚洲女人高潮大叫| 日韩免费一级| 黄色小视频在线播放| 国产精品三级在线观看| 久操视频在线| 久久精品第九区免费观看| 日韩伦理在线一区| 国产日韩一区二区三区| 日韩欧美高清一区二区三区| 国产乱码精品一区二区三区四区|