一个简单的PHP Web爬虫:Goutte
jopen
10年前
Goutte是一个屏幕抓取和web爬虫PHP库。
Goutte提供了一个很好的API来抓取网站和从服务器响应的HTML/ XML提取数据。
要求
Goutte depends on PHP 5.4+ and Guzzle 4+.
Tip
If you need support for PHP 5.3 or Guzzle 3, use Goutte 1.0.6.
安装
Add fabpot/goutte as a require dependency in your composer.json file:
php composer.phar require fabpot/goutte:~2.0
使用
Create a Goutte Client instance (which extendsSymfony\Component\BrowserKit\Client):
use Goutte\Client; $client = new Client();
Make requests with the request() method:
// Go to the symfony.com website $crawler = $client->request('GET', 'http://www.symfony.com/blog/');
The method returns a Crawler object (Symfony\Component\DomCrawler\Crawler).
Fine-tune cURL options:
$client->getClient()->setDefaultOption('config/curl/'.CURLOPT_TIMEOUT, 60);
点击链接:
// Click on the "Security Advisories" link $link = $crawler->selectLink('Security Advisories')->link(); $crawler = $client->click($link);
抽取数据:
// Get the latest post in this category and display the titles $crawler->filter('h2.post > a')->each(function ($node) { print $node->text()."\n"; });
提交表单:
$crawler = $client->request('GET', 'http://github.com/'); $crawler = $client->click($crawler->selectLink('Sign in')->link()); $form = $crawler->selectButton('Sign in')->form(); $crawler = $client->submit($form, array('login' => 'fabpot', 'password' => 'xxxxxx')); $crawler->filter('.flash-error')->each(function ($node) { print $node->text()."\n"; });