mfsousa / goutte
A simple PHP Web Scraper
Installs: 15
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 1 007
Type:application
Requires
- php: >=5.3.0
- ext-curl: *
- guzzle/http: ~3.1
- symfony/browser-kit: ~2.1
- symfony/css-selector: ~2.1
- symfony/dom-crawler: ~2.1
- symfony/finder: ~2.1
- symfony/process: ~2.1
Requires (Dev)
- guzzle/plugin-history: ~3.1
- guzzle/plugin-mock: ~3.1
This package is not auto-updated.
Last update: 2025-03-25 08:15:23 UTC
README
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.
Requirements
Goutte works with PHP 5.3.3 or later.
Installation
Installing Goutte is as easy as it can get. Download the Goutte.phar file and you're done!
Usage
Require the Goutte phar file to use Goutte in a script:
require_once '/path/to/goutte.phar';
Create a Goutte Client instance (which extends
Symfony\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
).
Click on links:
// Click on the "Security Advisories" link $link = $crawler->selectLink('Security Advisories')->link(); $crawler = $client->click($link);
Extract data:
// Get the latest post in this category and display the titles $crawler->filter('h2.post > a')->each(function ($node) { print $node->text()."\n"; });
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"; });
More Information
Read the documentation of the BrowserKit and DomCrawler Symfony Components for more information about what you can do with Goutte.
Technical Information
Goutte is a thin wrapper around the following fine PHP libraries:
- Symfony Components: BrowserKit, ClassLoader, CssSelector, DomCrawler, Finder, and Process;
- Guzzle HTTP Component.
License
Goutte is licensed under the MIT license.