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

首頁 > 開發 > PHP > 正文

php實現爬取和分析知乎用戶數據

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

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

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

無圖無真相

移動端分析數據截圖

php實現爬取和分析知乎用戶數據

pc端分析數據截圖

php實現爬取和分析知乎用戶數據

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

  1. curl爬取知乎網頁數據
  2. 正則分析知乎網頁數據
  3. 數據數據入庫和程序部署
  4. 數據分析和呈現

curl爬取網頁數據

PHP的curl擴展是PHP支持的,允許你與各種服務器使用各種類型的協議進行連接和通信的庫。是一個非常便捷的抓取網頁的工具,同時,支持多線程擴展。

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

獲取頁面cookie

 

復制代碼代碼如下:

// 登錄知乎,打開個人中心,打開控制臺,獲取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   :成功與否標志 */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); //設置請求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; }

正則分析網頁數據分析新鏈接,進一步爬取

對于抓取過來的網頁進行存儲,要想進行進一步的爬取,頁面必須包含有可用于進一步爬取用戶的鏈接。通過對知乎頁面分析發現:在個人中心頁面中有關注人和部分點贊人和被關注人。
如下所示

 

復制代碼代碼如下:

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

 

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

 

復制代碼代碼如下:

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

 

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

分析用戶數據,提供分析

通過正則可以進一步匹配出更多的該用戶數據,直接上碼。

// 獲取用戶頭像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 ;結束 中文preg_match('/<input.+name=/"?gender/"?.+value=/"?1/"?.+([/x{4e00}-/x{9fa5}]+).+/;/u', $str, $match_sex);$user_sex = $match_sex[1];// 匹配地區//<span class="location item" style="margin: 0px; padding: 0px; width: 660px; overflow: hidden; clear: both;">		
# 官方的最優批量插入INSERT INTO yourtable VALUES (1,2), (5,5), ...;

部署操作。程序在抓取過程中,有可能會出現異常掛掉,為了保證高效穩定,盡可能的寫一個定時腳本。每隔一段時間干掉,重新跑,這樣即使異常掛掉也不會浪費太多寶貴時間,畢竟,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 &  

數據分析呈現

數據的呈現主要使用echarts 3.0,感覺對于移動端兼容還不錯。兼容移動端的頁面響應式布局主要通過幾個簡單的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 ;結束 中文preg_match('/<input.+name=/"?gender/"?.+value=/"?1/"?.+([/x{4e00}-/x{9fa5}]+).+/;/u', $str, $match_sex);$user_sex = $match_sex[1];// 匹配地區//<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];// 匹配學歷// <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];// 匹配關注話題數量// 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];// 關注人數// <span class="zg-gray-normal">關注了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];

不足和待學習

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

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


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性猛交xxxx乱大交| 成人免费淫片视频软件| 成人久久久久久久| 欧美日韩加勒比精品一区| 色悠久久久久综合先锋影音下载| 国产噜噜噜噜久久久久久久久| 黄色一区二区在线观看| 精品激情国产视频| 欧美最顶级丰满的aⅴ艳星| 国产成人精品综合久久久| 一本色道久久88综合亚洲精品ⅰ| 中文欧美日本在线资源| 麻豆一区二区在线观看| 成人免费视频97| 久久久精品2019中文字幕神马| 久久成年人免费电影| 国产精品 欧美在线| 国产精品久久久久久久美男| 精品亚洲一区二区三区在线观看| 亚洲丝袜av一区| 日韩中文视频免费在线观看| 成人日韩av在线| 奇米四色中文综合久久| 欧美日韩在线视频首页| 国产欧洲精品视频| 欧美精品免费在线观看| 亚洲 日韩 国产第一| 日韩精品在线第一页| 久久国产精品偷| 91精品国产色综合久久不卡98| 亚洲精品中文字幕有码专区| 欧美—级高清免费播放| 亚洲香蕉成人av网站在线观看| 成人a级免费视频| 日韩亚洲欧美中文高清在线| 精品亚洲精品福利线在观看| 亚洲午夜色婷婷在线| 久久久久久成人| 久久久天堂国产精品女人| 欧美性生交xxxxxdddd| 国产成人综合精品在线| 欧美午夜激情在线| 日韩禁在线播放| 日韩美女视频中文字幕| 亚洲福利影片在线| 中文字幕亚洲一区在线观看| 中文字幕精品一区二区精品| 91夜夜揉人人捏人人添红杏| 欧美日韩一区二区三区| 国产午夜精品免费一区二区三区| 欧美激情综合亚洲一二区| 国产精品日韩欧美大师| 91高清免费在线观看| 亚洲视频日韩精品| 欧美成人免费播放| 国产三级精品网站| 久久久久久久久久久91| 国产精品一久久香蕉国产线看观看| 精品国产一区av| 啪一啪鲁一鲁2019在线视频| 久久精品精品电影网| 日本免费一区二区三区视频观看| 亚洲国产中文字幕久久网| 欧美日韩性生活视频| 日韩免费av片在线观看| 亚洲精品91美女久久久久久久| 中文字幕在线观看日韩| 国产日韩欧美在线看| 国产精品成人免费视频| 亚洲国产精久久久久久久| 色综合久久88色综合天天看泰| 久久久99免费视频| 中文字幕一区二区三区电影| 亚洲bt欧美bt日本bt| 国产精品一区=区| 日韩成人在线视频网站| 国产精品入口尤物| 国产精品福利小视频| 国产一区二区三区四区福利| 国产精品高清网站| 97精品在线视频| 日韩毛片在线观看| 国产69久久精品成人看| 在线成人一区二区| 欧美日韩国产黄| 欧美一区二区三区免费观看| 日本久久中文字幕| 亚洲天堂精品在线| 欧美最猛性xxxxx免费| 国产精品2018| 成人免费大片黄在线播放| 久久香蕉国产线看观看av| 亚洲大胆人体av| 中文字幕久久久av一区| 欧美乱大交xxxxx另类电影| 欧美日韩国产中字| 97久久超碰福利国产精品…| 欧美性xxxxxx| 69久久夜色精品国产69| 日韩欧美中文第一页| 亚洲美女av网站| 国产日韩欧美夫妻视频在线观看| 久久久av电影| 亚洲精品视频网上网址在线观看| 成人免费激情视频| 欧美精品www| 亚洲男人天堂手机在线| 成人做爰www免费看视频网站| 久热精品视频在线观看一区| 美女视频黄免费的亚洲男人天堂| 日韩有码在线观看| 亚洲精品久久视频| 色哟哟网站入口亚洲精品| 成人a级免费视频| 久久91超碰青草是什么| 91久久精品日日躁夜夜躁国产| 91影视免费在线观看| 亚州精品天堂中文字幕| 欧美日产国产成人免费图片| 欧美激情国产精品| 日韩免费观看网站| 国产精品久久久久久久9999| 亚洲国产又黄又爽女人高潮的| 97激碰免费视频| 国产精品都在这里| 深夜精品寂寞黄网站在线观看| 欧美日韩在线视频观看| 色偷偷综合社区| 日韩中文在线不卡| 国产精品九九久久久久久久| 国产精品男人爽免费视频1| 欧美日韩一区二区在线| 国产欧美日韩中文字幕在线| 亚洲欧美综合v| 欧美亚洲午夜视频在线观看| 亚洲国产精品高清久久久| 久久国产一区二区三区| 欧美性猛交xxxx免费看久久久| 尤物yw午夜国产精品视频| 日韩高清免费观看| 精品国产乱码久久久久久天美| 国产精品色婷婷视频| 欧美视频在线观看 亚洲欧| 欧美美女15p| 亚洲综合中文字幕在线| 米奇精品一区二区三区在线观看| 亚洲精品黄网在线观看| 亚洲欧美综合v| 亚洲精品久久7777777| 日本久久久久久久久久久| 欧美日韩亚洲视频一区| 92看片淫黄大片欧美看国产片| 久久精品电影一区二区| 国产性色av一区二区| 欧美激情第6页| 97国产在线视频| 国产精品99久久久久久久久| 欧美在线激情网| 国产香蕉精品视频一区二区三区| 成人免费高清完整版在线观看| 国产成人久久精品| 精品免费在线视频| 国产精品av免费在线观看| 亚洲夜晚福利在线观看|