过期域名预定抢注

 找回密碼
 免费注册

從0開始學採集------中級篇:使用Curl抓取網頁內容

 火... [複製鏈接]
發表於 2014-10-29 21:58:04 | 顯示全部樓層 |閱讀模式
本帖最後由 kevinmy 於 2014-10-29 22:05 編輯 2 n# r( |4 |3 z+ A& Z2 u) o

  A* I. ?% G- _$ Y前言:: \, [) M+ ]4 E
在初級篇和中級篇之前期準備我們介紹了利用火車頭採集內容並發佈到wordpress的過程(帖子地址:http://www.luosuo.net/old/thread-121090-1-1.html),也介紹如何在本機搭建PHP環境,在結尾處貼出了一個由3行代碼組成的最簡易的採集小程序(帖子地址:http://www.luosuo.net/old/thread-121117-1-1.html),帖子發出20多分鐘,就得到了朋友們的積極反饋,會員:mulao在回帖中提到「不建議使用file_get_contents採集,推薦使用php的curl庫」並在帖中貼出了兩者9 J) r, C' u) F8 `& f! b8 K
讀取google.com首頁的效率對比。mulao的說法是正確的,curl和file_get_contents對比起來,不僅是效率高,同時它還支持很多協議,如HTTP、FTP、TELNET等,用curl還可以完成一些高難度任務,比如:處理coockies、驗證、表單提交、文件上傳等等。file_get_contents相比較起來只有一個簡單、讓新手樹立信心的優勢了,不知道昨天的3行採集程序有多少人去實驗了?好,今天我們正式開始中級篇:使用Curl抓取網頁內容
! G. z6 K# g) i/ Z7 [! D6 l! {4 g% {
在學習更為複雜的功能之前,先來看一下在PHP中建立curl請求的基本步驟:1 R4 G- p( A5 U( S2 B
1.初始化
  r8 A& D3 O/ H2.設置變量5 z2 R# U6 `/ a* R
3.執行並獲取結果* K7 r! X8 Q& U7 Z9 V, A
4.釋放curl句柄
/ |% E7 a; x" Q/ o! n6 W; C( H9 N% z
以下為採集TGL帖子列表的代碼:
- A' A0 ]2 x5 ^4 b! V! s<?php ! e9 C* j+ O' w( r
set_time_limit(0);//設置程序執行時間 2 Y' x  D1 J$ i; `& J
header("Content-Type: text/html; charset= utf-8"); //設置頁面的編碼,不設置會亂碼 ! |1 g5 Y- `2 l' x$ o2 w0 u, {

- J+ l% I5 P6 B& T" E" b$url="http://www.luosuo.net/old/forum-4-1.html";
: \" ^. C3 F0 L7 ~$ch = curl_init($url);//初始化 ' v% y8 h- X( @
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//返回的內容我們是作為變量儲存, 而不輸出,所以這裡選1.
; q$ }5 ?2 m2 s+ o* o! J$contents = curl_exec($ch);// 運行cURL,請求網頁
8 `$ v7 M9 B4 Kpreg_match_all('{<a href="([^"]+)" class="xst" >(.*)</a>}',$contents,$matches);//正則匹配想要的內容
6 X/ [1 ~( Z; G7 `% G+ Ycurl_close($ch);// 關閉URL請求 , p$ F$ m+ ^% a) S: b9 e( A

+ p7 {- p9 [& H6 bfor ($i=0;$i<count($matches[1]);$i++)//for循環結構很常用,這裡的作用是循環記錄總數的的次數,每次循環中可以任意處理採集到的內容 $ Z7 j1 i" v) D# Z/ k( e
{ ) e% j& q7 J; O6 ?% _
$title = $matches[2][$i]; 3 Z* I& u/ M3 h( m
$geturl = $matches[1][$i];
+ y( X6 e4 F( g, n* necho "我要的標題是:" . $title. "<br/>" . "對應的網址是:" . $geturl . "<br/><br/><br/>";
" P9 c. q5 N4 O& N} ' ~3 ?6 i- C7 R6 t$ @* T
?>
# h5 e1 o7 e9 `" E# M' E8 P5 h

6 e5 J  q" j# U3 |代碼運行的結果如下:
4 P  h+ ^7 |! B9 x
$ \" j. J4 t8 i( ?& I4 v/ H aa.png * u# L$ F- u% q3 p( Z/ H" ]

8 q9 [- A4 C: [0 h要點:
1 K, I( C/ W/ T- B5 \$ L$ o* V& e
* K- |3 Z# Y- u+ l- P& @1.在curl這段代碼中 curl_setopt() )最為重要,通過參數指定URL請求的各個細節來實現一些複雜的功能,但由於參數眾多,要一次性看完並理解也比較困難,所以今天我們只用了這一個選項,curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);這裡的參數我們設置為1或者true的原因是,返回的內容我們要作為變量儲存, 而不直接輸出到屏幕上。
7 L$ E) Q0 j0 ~' M
* Z: D2 c* Q+ m2. preg_match_all這段正則匹配,想要學好採集,正則是必須學會的。這個一句兩句說不清,請百度搜索:正則表達式,有很多教程。+ e7 T  Y) a+ s- g$ ^

  b' d$ Y% N, _8 q( f+ C. c3 e3.for循環讀出數組內的內容。這個結構在採集中經常用到的。
6 Z* U9 Z0 m- @7 u/ y0 h
- D$ Q0 N* C2 Q8 ?1 R
* H' t0 u- |( ?* w9 {" i1 b0 V9 U
今天的教程好像解釋的不清楚,也不知道該寫點什麼,可能還是因為本人水平有限,無法簡單易懂的說明原理。有問題回帖吧
( U1 ^  B: F. u$ o: t; n
7 G0 x. K% c& g& ^  X/ J3 B  ]
0 y6 g) b* l$ Z3 W5 Y

- }! M+ Q+ J6 S$ u- g1 I" c8 ]% d- H, u3 z& O6 x

. C1 T' n" @1 s; ?+ n2 T5 i* d6 B5 g6 M- x

- e# Y1 g7 _1 t! k+ U" T3 f: |7 @) h9 m) ~+ @' B

評分

參與人數 14點點 +51 收起 理由
采姑娘的小蘑菇 + 1 这个很强大,不会php的我都看懂了.
useejack + 1 谢谢分享!
ebookyx + 1
Rick + 1 谢谢分享!
1988chg + 1
minlab + 2 有見地
xx19941215 + 1 楼主好牛
ryan2101 + 1
月光飞燕 + 30
Leeker + 1 打赏点辛苦钱
youdy17 + 1 送花花~~~
乐乐 + 5 很不错
roror999 + 3 必须加币,必须的!
wawylysys + 2 鼓勵

查看全部評分

回復

使用道具 舉報

發表於 2014-10-29 22:37:28 | 顯示全部樓層
樓主也會PHP,不會PHP程序員出身吧。現在不用上班了吧( ?0 ^% @" s5 }
回復 给力 爆菊

使用道具 舉報

發表於 2014-10-29 22:42:01 | 顯示全部樓層
謝謝分享~~~~~~~~~~~~~~~~~~~~~~~! f: p3 o7 Q4 q
回復 给力 爆菊

使用道具 舉報

發表於 2014-10-29 22:49:08 | 顯示全部樓層
感謝樓主分享,期待後續大作; }! f$ {$ G( y; T1 M( @2 r' A; W
回復 给力 爆菊

使用道具 舉報

發表於 2014-10-29 23:56:25 | 顯示全部樓層
這個可以收藏下。。;。: I. _# H) a# R$ b: V
回復 给力 爆菊

使用道具 舉報

發表於 2014-10-30 00:03:01 | 顯示全部樓層
占座 學習                                                         / u. G: y; g" |, w+ b& F/ o
回復 给力 爆菊

使用道具 舉報

發表於 2014-10-30 00:22:26 來自手機 | 顯示全部樓層
謝謝樓主分享,我就懂點PHP::::/ s; W" I5 H8 y! [. S1 j
回復 给力 爆菊

使用道具 舉報

發表於 2014-10-30 00:22:41 | 顯示全部樓層
mark   學習                                 + u! k8 c# X# Y: t+ L7 e; }/ C
回復 给力 爆菊

使用道具 舉報

發表於 2014-10-30 10:42:42 | 顯示全部樓層
前排占座,  好好學習9 s6 _+ E+ `" @4 p
回復 给力 爆菊

使用道具 舉報

發表於 2014-10-30 10:55:33 | 顯示全部樓層
$i<count($matches[1]);    這個count()是個函數嗎?
4 H! g6 b$ _  Q7 w" I5 a
回復 给力 爆菊

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 免费注册

本版積分規則

过期高净值品牌域名预定抢注

點基跨境 數位編輯創業論壇

GMT+8, 2025-7-19 06:49

By DZ X3.5

小黑屋

快速回復 返回頂部 返回列表