Goutte is a screen scraping and web crawling library for PHP. It provides an API to navigate through web pages and extract data using CSS selectors, XPath expressions, and other techniques. When using Goutte for data extraction, you typically use the following common selectors:
CSS Selectors
CSS selectors are the most common and straightforward way to select elements within an HTML document. They are used to target elements based on their id, class, attributes, or hierarchy in the DOM (Document Object Model). Here are some examples of CSS selectors:
Element Selector: Selects all elements of a specific type.
$crawler->filter('div'); // Selects all <div> elements
ID Selector: Selects a single element with a specific id.
$crawler->filter('#unique-id'); // Selects element with id="unique-id"
Class Selector: Selects all elements with a specific class.
$crawler->filter('.class-name'); // Selects all elements with class="class-name"
Attribute Selector: Selects elements with a specific attribute or attribute value.
$crawler->filter('[attribute="value"]'); // Selects all elements with a specific attribute value
Pseudo-classes: Selects elements using pseudo-classes like
:first-child
,:last-child
,:nth-child(n)
, etc.$crawler->filter('div:first-child'); // Selects the first child <div> of its parent
XPath Selectors
XPath is a powerful language for selecting nodes from an XML document, which is also applicable to HTML documents. Goutte allows you to use XPath expressions to select elements:
$crawler->filterXPath('//div[@class="class-name"]'); // Selects all <div> elements with class="class-name"
Text, Attribute, and Other Extractors
Once you have selected an element or a set of elements using CSS or XPath selectors, you can extract various pieces of data:
Text Content: To get the text content of the selected elements.
$text = $crawler->filter('h1')->text();
HTML Content: To get the HTML content inside the selected elements.
$html = $crawler->filter('div.content')->html();
Attributes: To get the value of an attribute of the selected element.
$href = $crawler->filter('a')->attr('href');
Count: To count the number of selected elements.
$count = $crawler->filter('div')->count();
Each Function: To iterate over selected elements and apply a function to each.
$crawler->filter('ul > li')->each(function ($node) { // Do something with each <li> element });
Combining Selectors
You can also chain selectors to refine your selection:
$crawler->filter('div.content')->filter('p')->eq(1); // Selects the second <p> within div with class="content"
Remember that these selectors are used with Goutte's filter
and filterXPath
methods, which return a new Crawler instance that can be further filtered or inspected to extract the data you need.
When using Goutte, ensure that your web scraping activities are compliant with the website's terms of service and legal regulations like the GDPR. Also, respect robots.txt
rules and try to minimize the load on the website's servers by making requests at a reasonable rate.