亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP如何實現抓取百度搜索結果并分析數據結構

發布時間:2020-09-26 09:26:19 來源:億速云 閱讀:544 作者:小新 欄目:編程語言

這篇文章主要介紹PHP如何實現抓取百度搜索結果并分析數據結構,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

PHP網絡爬蟲實踐:抓取百度搜索結果,并分析數據結構

百度的搜索引擎有反爬蟲機制,我先直接用guzzle試試水。代碼如下:

<?php
/**
 * Created by Benjiemin
 * Date: 2020/3/5
 * Time: 14:58
 */
require ('./vendor/autoload.php');
use QL\QueryList;
//進入網頁
$jar = new \GuzzleHttp\Cookie\CookieJar;
$client = new GuzzleHttp\Client(['cookies' => true]);
$ql = $client->request('GET', 'https://www.baidu.com', [
    'cookies' => $jar
]);
if($ql->getStatusCode()!=200){
    echo '網站狀態不正常';die;
}
echo  $ql->getBody();

PHP如何實現抓取百度搜索結果并分析數據結構

百度直接攔截了,進了跳轉頁面,我試試加個瀏覽器頭文件,再試試。

修改后的header如下:

$ql = $client->request('GET', 'https://www.baidu.com', [
    'cookies' => $jar,
    'headers' => [
    'Accept-Encoding' => 'gzip, deflate, br',
    'Accept'     => 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8',
    'Accept-Language'      => 'zh-CN,zh;q=0.9,en;q=0.8',
    'Cache-Control'      => 'no-cache',
    'Connection'      => 'keep-alive',
    'User-Agent'      => 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36',
]
]);

我測試了下,網站打開了。

PHP如何實現抓取百度搜索結果并分析數據結構

我們繼續,輸入關鍵詞,并搜索,結果發現被安全攔截了,所以我感覺直接用GuzzleHttp搞不動,于是我繼續我的神器:jaeger/querylist和jaeger/querylist-puppeteer。

安裝步驟:

1.安裝依賴

在這之前,要先啟用php的proc_open函數,否則無法安裝完整

composer install jaeger/querylist
composer install jaeger/querylist-puppeteer

2.安裝nodejs

yum install nodejs

3.安裝npm

4.安裝@nesk/puphpeteer

npm install @nesk/puphpeteer

5.PHP啟用proc_open

代碼如下:

<?php
/**
 * Created by Benjiemin
 * Date: 2020/3/5
 * Time: 14:58
 */
require ('./vendor/autoload.php');
use QL\QueryList;
use QL\Ext\Chrome;
$ql = QueryList::getInstance();
// 注冊插件,默認注冊的方法名為: chrome
$ql->use(Chrome::class);
 $ql->chrome(function ($page,$browser) {
    $page->goto('https://www.baidu.com');
    // 這里故意設置一個很長的延長時間,讓你可以看到chrome瀏覽器的啟動
    sleep(3);
    //輸入關鍵詞
    $wd = '簡慶旺博客';
    $page->type("input[id='kw']",$wd);
    sleep(1);
    //點擊搜索
    $page->click("input[type='submit']");
    //等待搜索結果
    sleep(3);
    //獲取結果
    $html = $page->content();
    //用jquery選擇器抽取結果
    $rules = array(
        'title'=>['#content_left h4 a','text'],//標題
        'url'=>['#content_left h4 a','href'],//跳轉網址
        'description'=>['div .c-abstract','text'],//描述
    );
    $ql = QueryList::html($html);
    $rt = $ql->rules($rules)->query()->getData();
    //如果有需要,可以把$rt入庫,以及做其他操作
    sleep(10);
    $browser->close();
    // 返回值一定要是頁面的HTML內容
    return $html;
},[
    'headless' => false, // 啟動可視化Chrome瀏覽器,方便調試
    'devtools' => false, // 打開瀏覽器的開發者工具
])->find('title')->text();

$rt是我的結果集合,打印下,如下

PHP如何實現抓取百度搜索結果并分析數據結構

PHP如何實現抓取百度搜索結果并分析數據結構

以上是PHP如何實現抓取百度搜索結果并分析數據結構的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

望奎县| 苗栗县| 西畴县| 宣恩县| 扶余县| 堆龙德庆县| 卢湾区| 敖汉旗| 逊克县| 左云县| 玛多县| 江安县| 郯城县| 莱芜市| 安西县| 临夏市| 长岛县| 河西区| 夹江县| 遂昌县| 龙川县| 祁连县| 金山区| 灵台县| 阳曲县| 宣城市| 弥勒县| 乌什县| 四子王旗| 钟山县| 桑日县| 黎城县| 濮阳市| 安乡县| 仁寿县| 柳江县| 徐闻县| 沾化县| 南康市| 博客| 安塞县|