Goutte is a screen scraping and web crawling library for PHP.
Goutte provides a nice API to crawl websites and extract data from the HTML/XML responses.
Goutte depends on PHP 5.5+ and Guzzle 6+.
Tip
If you need support for PHP 5.4 or Guzzle 4-5, use Goutte 2.x (latest phar).
If you need support for PHP 5.3 or Guzzle 3, use Goutte 1.x (latest phar).
Add fabpot/goutte
as a require dependency in your composer.json
file:
Create a Goutte Client instance (which extends Symfony\Component\BrowserKit\Client
):
Make requests with the request()
method:
The method returns a Crawler
object (Symfony\Component\DomCrawler\Crawler
).
Fine-tune cURL options:
Click on links:
Extract data:
Submit forms:
$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";
});
Read the documentation of the BrowserKit and DomCrawler Symfony Components for more information about what you can do with Goutte.
Goutte is pronounced goot
i.e. it rhymes with boot
and not out
.
Goutte is a thin wrapper around the following fine PHP libraries:
- Symfony Components: BrowserKit, CssSelector and DomCrawler;
- Guzzle HTTP Component.
Goutte is licensed under the MIT license.