-
-
-PHPScraper is a universal web-scraping util for PHP, built with simplicity in mind. The goal is to make xPath Selectors *optional* and avoid the commonly needed boilerplate code. Just create an instance of *PHPScraper*, *go* to a website, and start collecting data. The examples below tell the story much better. Have a look!
-
-Under the hood, it uses
-
-- [Goutte](https://github.com/FriendsOfPHP/Goutte) to access the web
-- [League/URI](https://github.com/thephpleague/uri) to process URLs
-- [donatello-za/rake-php-plus](https://github.com/donatello-za/rake-php-plus) to extract and analyze keywords
-
-See [composer.json](https://github.com/spekulatius/PHPScraper/blob/master/composer.json) for more details.
-
-
-:timer_clock: PHPScraper in 5 Minutes explained
------------------------------------------------
-
-Here are a few impressions of the way the library works. More examples are this website in the various sections.
-
-### Basics: Flexible Calling as an Attribute or Method
-
-All scraping functionality can be accessed either as a function call or a property call. For example, the title can be accessed in two ways:
-
-```php
-// Prep
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://google.com');
-
-// Returns "Google"
-echo $web->title;
-
-// Also returns "Google"
-echo $web->title();
-```
-
-### :battery: Batteries included: Meta-Data, Links, Images, Headings, Content, Keywords, ...
-
-Many common use cases are covered already. You can find prepared extractors for various HTML tags, including interesting attributes. You can filter and combine these to your needs. In some cases there is an option to get a simple or detailed version, here in the case of `linksWithDetails`:
-
-```PHP
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Contains:
-//
-//
-//
-//
-$web->go('https://test-pages.phpscraper.de/links/image-urls.html');
-
-// Get the first link on the page and print the result
-print_r($web->linksWithDetails[0]);
-// [
-// 'url' => 'https://placekitten.com/456/500',
-// 'protocol' => 'https',
-// 'text' => '',
-// 'title' => null,
-// 'target' => null,
-// 'rel' => 'ugc',
-// 'image' => [
-// 'https://placekitten.com/456/400',
-// 'https://placekitten.com/456/300'
-// ],
-// 'isNofollow' => false,
-// 'isUGC' => true,
-// 'isSponsored' => false,
-// 'isMe' => false,
-// 'isNoopener' => false,
-// 'isNoreferrer' => false,
-// ]
-```
-
-::: tip Null
-If there aren't any matching elements (here links) on the page, an empty array will be returned.
-
-For methods that normally return a single string (e.g. `title`), `null` will be returned in this case.
-:::
-
-Details such as `follow_redirects`, etc. are optional configuration parameters (see below).
-
-Most of the DOM should be covered using these methods:
-
-- several [meta-tags](/examples/scrape-meta-tags.html) and other [``-information](/examples/scrape-header-tags.html)
-- [Social-Media information](/examples/scrape-social-media-meta-tags.html) like Twitter Card and Facebook Open Graph
-- Content: [Headings](/examples/headings.html), [Outline](/examples/outline.html), [Texts](/examples/paragraphs.html) and [Lists](/examples/lists.html)
-- [Keywords](/examples/extract-keywords.html)
-- [Images](/examples/scrape-images.html) & [Links](/examples/scrape-links.html).
-
-**More examples are included in the [tests](https://github.com/spekulatius/PHPScraper/tree/master/tests).**
-
-
-### Download Files
-
-Besides processing the content on the page itself, you can download files using `fetchAsset`:
-
-```php
-// Absolute URL
-$csvString = $web->fetchAsset('https://test-pages.phpscraper.de/test.csv');
-
-// Relative URL after navigation
-$csvString = $web
- ->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html')
- ->fetchAsset('/test.csv');
-```
-
-You will only need to write the content into a file or cloud storage.
-
-::: warning 404s
-If the intended URL isn't available an exception will be thrown. Make sure to handle this case by wrapping your code in a try-catch block:
-
-```php
-try {
- // ...
-} catch (\Exception $e) {
- // ...
-}
-```
-:::
-
-
-### Process the RSS feeds, `sitemap.xml`, etc.
-
-PHPScraper can assist in collecting feeds such as [RSS feeds, `sitemap.xml`-entries and static search indexes](/examples/scrape-feeds.html). This can be useful when deciding on the next page to crawl or build up a list of pages on a website.
-
-Here we are processing the sitemap into a set of [`FeedEntry`-DTOs](https://github.com/spekulatius/PHPScraper/blob/pre-release-tweaks/src/DataTransferObjects/FeedEntry.php):
-
-```php
-(new \Spekulatius\PHPScraper\PHPScraper)
- ->go('https://phpscraper.de')
- ->sitemap
-
-// array(131) {
-// [0]=>
-// object(spekulatius\DataTransferObjects\FeedEntry)#165 (3) {
-// ["title"]=>
-// string(0) ""
-// ["description"]=>
-// string(0) ""
-// ["link"]=>
-// string(22) "https://phpscraper.de/"
-// }
-// [1]=>
-// ...
-```
-
-::: tip Fallback-Methods
-Whenever post-processing is applied, you can fall back to the underlying `*Raw`-methods.
-:::
-
-### Process CSV-, XML- and JSON files and URLs
-
-PHPScraper comes out-of-the-box with file / URL processing methods for CSV-, XML- and JSON:
-
-- `parseJson`
-- `parseXml`
-- `parseCsv`
-- `parseCsvWithHeader` (generates an asso. array using the first row)
-
-Each method can process both strings as well as URLs:
-
-```php
-// Parse CSV into a simple array:
-$csv = $web->parseJson('[{"title": "PHP Scraper: a web utility for PHP", "url": "https://phpscraper.de"}]');
-// [
-// 'title' => 'PHP Scraper: a web utility for PHP',
-// 'url' => 'https://phpscraper.de'
-// ]
-
-// Fetch and parse CSV into a simple array:
-$csv = $web->parseCsv('https://test-pages.phpscraper.de/test.csv');
-// [
-// ['date', 'value'],
-// ['1945-02-06', 4.20],
-// ['1952-03-11', 42],
-// ]
-
-// Fetch and parse CSV with first row as header into an asso. array structure:
-$csv = $web->parseCsvWithHeader('https://test-pages.phpscraper.de/test.csv');
-// [
-// ['date' => '1945-02-06', 'value' => 4.20],
-// ['date' => '1952-03-11', 'value' => 42],
-// ]
-```
-
-::: tip Additional CSV parsing parameters
-Additional CSV parsing parameters such as separator, enclosure and escape are possible.
-:::
-
-
-### There is more!
-
-There are plenty of examples on the PHPScraper website and in the [tests](https://github.com/spekulatius/PHPScraper/tree/master/tests).
-
-Check the [`playground.php`](https://github.com/spekulatius/PHPScraper/blob/master/playground.php) if you prefer learning by doing. You get it up and running with:
-
-```bash
-$ git clone git@github.com:spekulatius/PHPScraper.git && composer update
-```
-
-:muscle: Roadmap
-----------------
-
-The future development is organized into [milestones](https://github.com/spekulatius/PHPScraper/milestones?direction=asc&sort=title). Releases follow [semver](https://semver.org/).
-
-### v1: [Building the first stable version](https://github.com/spekulatius/PHPScraper/milestone/4)
-
-- Improve documentation and examples.
-- Organize code better (move websites into separate repos, etc.)
-- Add support for feeds and some typical file types.
-
-### v2: [Expand the functionality and cover more 'types'](https://github.com/spekulatius/PHPScraper/milestone/5)
-
-- Expand to parse a wider range of types, elements, embeds, etc.
-- Improve performance with caching and concurrent fetching of assets
-- Minor improvements for parsing methods
-
-### v3: [Expand to provide more guidance on building custom scrapers on top of PHPScraper](https://github.com/spekulatius/PHPScraper/milestone/6)
-
-TBC.
-
-
-:heart_eyes: Sponsors
----------------------
-
-PHPScraper is proudly supported by:
-
-
-
-If you find PHPScraper useful to your work or simply want to support the development, please consider a [sponsorship](https://github.com/sponsors/spekulatius) or [donation](https://www.buymeacoffee.com/spekulatius). Thank you :muscle:
-
-
-:gear: Configuration (optional)
--------------------------------
-
-If needed, you can use the following configuration options:
-
-### User Agent
-
-You can set the browser agent using `setConfig`:
-
-```php
-$web->setConfig([
- 'agent' => 'Mozilla/5.0 (X11; Linux x86_64; rv:107.0) Gecko/20100101 Firefox/107.0'
-]);
-```
-
-It defaults to `Mozilla/5.0 (compatible; PHP Scraper/1.x; +https://phpscraper.de)`.
-
-### Proxy Support
-
-You can configure proxy support with `setConfig`:
-
-```php
-$web->setConfig(['proxy' => 'http://user:password@127.0.0.1:3128']);
-```
-
-::: tip
-If you're looking for decent prices residential proxy, check [IProyal](https://iproyal.com?r=119987).
-:::
-
-### Timeout
-
-You can set the `timeout` using `setConfig`:
-
-```php
-$web->setConfig(['timeout' => 15]);
-```
-
-Setting the timeout to zero will disable it.
-
-### Disabling SSL
-
-While unrecommended, it might be required to disable SSL checks. You can do so using:
-
-```php
-$web->setConfig(['disable_ssl' => true]);
-```
-
-You can call `setConfig` multiple times. It stores the config and merges it with previous settings. This should be kept in mind in the unlikely use-case when unsetting values.
-
-
-:rocket: Installation with Composer
------------------------------------
-
-```bash
-composer require spekulatius/phpscraper
-```
-
-After the installation, the package will be picked up by the Composer autoloader. If you are using a common PHP application or framework such as Laravel or Symfony you can start scraping now :rocket:
-
-If you are using a framework such as Laravel, Symfony, Laminas, Phalcon, or CakePHP, you won't need this step. The autoloader is automatically included.
-If not or you are building a standalone-scraper, please include the autoloader in `vendor/` at the top of your file:
-
-```php
-
-
-Möchten Sie dieses Projekt unterstützen? [Schreib mir](https://peterthaleikis.com/contact).
-
-
-Beispiele: Code sagt mehr als Tausend Worte.
---------------------------------------------
-
-Hier sind einige Beispiele dafür, was die Web-Scraping-Bibliothek an dieser Stelle tun kann:
-
-### Meta-Informationen Scrapen:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- *
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Get the information:
-echo $web->author; // "Lorem ipsum"
-echo $web->description; // "Lorem ipsum dolor etc."
-echo $web->image; // "https://test-pages.phpscraper.de/assets/cat.jpg"
-```
-
-Nahezu alle Informationen können direkt als string oder array genutzt werden.
-
-
-### Scrapen von Inhalten, beispielsweise Bilder:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. This page contains two images:
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-var_dump($web->imagesWithDetails);
-/**
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'absolute path',
- * 'width' => null,
- * 'height' => null,
- * ],
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'relative path',
- * 'width' => null,
- * 'height' => null,
- * ]
- */
-```
-
-Hier werden einige zusätzliche, *optionale* Informationen im Array als Details zurückgegeben. Alternativ ist für dieses Beispiel ist auch eine vereinfachte Liste nur mit den Bildern mit `$web->images` verfügbar:
-
-```php
-// Wie oben.
-
-var_dump($web->images);
-/**
- * [
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- *
- * // Hinweis: Doppelt, da die Seite das Bild mehrfach enthält.
- */
-```
-
-Mehr Beispielcode finden Sie in den Einzelbeispielen und in den Tests.
-
-
-Installation
-------------
-
-Die Installation erfolgt üblicherweise mit [Composer](https://getcomposer.org).
-
-### Installation mit Composer
-
-```bash
-composer require spekulatius/phpscraper
-```
-
-Nach Abschluss der Installation wird das Paket vom Composer-Autoloader geladen. Damit wird in den meisten PHP applikationen sichergstellt, dass die Klassen entsprechend geladen werden können. Mit dem Scrapen kann direkt begonnen werden. Sie können nun eines der aufgeführten Beispiele oder weiteren Beispiele aus den `tests/` verwenden.
-
-### Verwendung in VanillaPHP-Projekten
-
-Wenn Sie ein VanillaPHP-Projekt bauen, müssen Sie den Autoloader oben im Skript einbinden:
-
-```php
-require 'vendor/autoload.php';
-```
-
-Wenn Sie ein Framework wie Laravel, Symfony, Laminas, Phalcon, oder CakePHP verwenden, brauchen Sie diesen Schritt nicht. Der Autoloader übernimmt die Arbeit.
-
-
-Konfiguration
--------------
-
-Die weitere Konfiguration ist optional. Unterhalb finden Sie die gegenwärtig verfügbaren Optionen:
-
-### Proxy
-
-Falls Sie Proxies benötigen können Sie PHPScraper wie folgt konfigurieren:
-
-```php
-$web->setConfig(['proxy' => 'http://user:password@127.0.0.1:3128']);
-```
-
-::: tip
-Falls Sie nach einem günstigen Proxy suchen ist [IProyal](https://iproyal.com?r=119987) einen Blick wert.
-:::
-
-### Timeout setzen
-
-Das `timeout` kann mit `setConfig` gesetzt werden:
-
-```php
-$web->setConfig(['timeout' => 15]);
-```
-
-Der timeout kann mit `0` gedeaktiviert werden.
-
-### Disabling SSL
-
-Während es nicht empfohlen ist, kann es notwendig sein die SSL checks zu deaktivieren. Dies kann wie folgt erreicht werden:
-
-```php
-$web->setConfig(['disable_ssl' => true]);
-```
-
-`setConfig` kann mehrfach aufgerufen werden. Es speichert die Konfiguration und merged frühere Einstellungen. Dies sollte bedacht werden, wenn man etwas zurücksetzen will.
-
-
-Ein Problem gefunden und gefixt? Super!
----------------------------------------
-
-Bevor Sie loslegen, machen Sie sich mit den [Contribution Guidelines](/contributing.html) vertraut. Bei Fragen bitte eine kurze Nachricht oder Email.
-
-
-Tests: Damit es wirklich funktioniert!
---------------------------------------
-
-Der Code wird grob mit End-to-End-Tests abgedeckt. Dazu werden einfache Webseiten unter *https://test-pages.phpscraper.de/* gehostet, geladen und geparst mit [PHPUnit](https://phpunit.de/). Diese Tests sind auch als Beispiele geeignet - siehe `tests/`!
-
-Trotzdem gibt es wahrscheinlich Randfälle, die nicht funktionieren und Probleme verursachen können. Wenn Sie einen finden, melden Sie bitte einen Fehler auf GitHub.
diff --git a/websites/de/apis/alibaba.md b/websites/de/apis/alibaba.md
deleted file mode 100644
index 38cd877..0000000
--- a/websites/de/apis/alibaba.md
+++ /dev/null
@@ -1,16 +0,0 @@
-# Alibaba/AliExpress Scraper API
-
-Das Team hinter PHP Scraper arbeitet daran, kommerzielle APIs für verschiedene gängige Anwendungsfälle und Plattformen bereitzustellen. Diese APIs werden nicht selbst gehostet. Sie müssen sich keine Gedanken über rotierende IPs/Proxies machen und einen Headless-Browser wie Puppeteer verwenden. Mit einem einfachen API-Aufruf erhalten Sie alle erforderlichen Informationen. Die Dienste werden auf der Grundlage einer attraktiven, nutzungsabhängigen Gebührenstruktur bereitgestellt.
-
-Für Alibaba erwägen wir die Implementierung einer API mit folgendem Umfang.
-
-## Vorgeschlagene unterstützte Endpunkte
-
-- Suche nach Produkten nach Schlüsselwort
-- Produktinformation abrufen
-
-Bitte beachten Sie, dass diese Informationen nicht endgültig sind und sich noch ändern können.
-
-## Plattform-Unterstützung
-
-Mit dem Ansatz, eine verwaltete API zu verwenden, müssen sich die Nutzer keine Gedanken mehr über rotierende Proxys, Skalierungsprobleme und Ausfälle machen. Außerdem wird eine breite Palette von Plattformen unterstützt. Sie können problemlos in NodeJS, Python (ohne Requests oder Beautifulsoap), Golang usw. integriert werden. Jede Plattform, die es erlaubt, GET-Anfragen auszuführen, kann so programmiert werden, dass sie Daten von diesem Dienst abruft.
diff --git a/websites/de/apis/amazon.md b/websites/de/apis/amazon.md
deleted file mode 100644
index c25b1ed..0000000
--- a/websites/de/apis/amazon.md
+++ /dev/null
@@ -1,22 +0,0 @@
-# Amazon Scraper API
-
-Das Team hinter PHP Scraper arbeitet daran, kommerzielle APIs für verschiedene gängige Anwendungsfälle und Plattformen bereitzustellen. Diese APIs werden nicht selbst gehostet. Sie müssen sich keine Gedanken über rotierende IPs/Proxies machen und einen Headless-Browser wie Puppeteer verwenden. Mit einem einfachen API-Aufruf erhalten Sie alle erforderlichen Informationen. Die Dienste werden auf der Grundlage einer attraktiven, nutzungsabhängigen Gebührenstruktur bereitgestellt.
-
-Für Amazon ziehen wir die Implementierung einer API mit folgendem Umfang in Betracht.
-
-## Vorgeschlagene unterstützte Endpunkte
-
-- Produktinformation abrufen
-- Empfehlungen abrufen
-- Informationen zu Bewertungen abrufen
-- Verkäufer-Informationen abrufen
-- Alle Verkäuferpreise abrufen
-- Nach Produkten suchen mit Schlüsselwörter oder per Verkäufer-ID
-
-::: tip
-Bitte beachten Sie, dass diese Liste der API-Endpunkte *nicht* endgültig ist und sich wahrscheinlich noch ändern wird.
-:::
-
-## Plattform-Unterstützung
-
-Mit dem Ansatz, eine verwaltete API zu verwenden, müssen sich die Nutzer keine Gedanken mehr über rotierende Proxys, Skalierungsprobleme und Ausfälle machen. Außerdem wird eine breite Palette von Plattformen unterstützt. Sie können problemlos in NodeJS, Python (ohne Requests oder Beautifulsoap), Golang usw. integriert werden. Jede Plattform, die es erlaubt, GET-Anfragen auszuführen, kann so programmiert werden, dass sie Daten von diesem Dienst abruft.
diff --git a/websites/de/apis/etsy.md b/websites/de/apis/etsy.md
deleted file mode 100644
index 7f83693..0000000
--- a/websites/de/apis/etsy.md
+++ /dev/null
@@ -1,22 +0,0 @@
-# Etsy Scraper API
-
-Das Team hinter PHP Scraper arbeitet daran, kommerzielle APIs für verschiedene gängige Anwendungsfälle und Plattformen bereitzustellen. Diese APIs werden nicht selbst gehostet. Sie müssen sich keine Gedanken über rotierende IPs/Proxies machen und einen Headless-Browser wie Puppeteer verwenden. Mit einem einfachen API-Aufruf erhalten Sie alle erforderlichen Informationen. Die Dienste werden auf der Grundlage einer attraktiven, nutzungsabhängigen Gebührenstruktur bereitgestellt.
-
-Für Etsy ziehen wir die Implementierung einer API mit folgendem Umfang in Betracht.
-
-## Vorgeschlagene unterstützte Endpunkte
-
-- Produktinformation abrufen
-- Empfehlungen abrufen
-- Informationen zu Bewertungen abrufen
-- Verkäufer-Informationen abrufen
-- Alle Verkäuferpreise abrufen
-- Nach Produkten suchen mit Schlüsselwörter oder per Verkäufer-ID
-
-::: tip
-Bitte beachten Sie, dass diese Liste der API-Endpunkte *nicht* endgültig ist und sich wahrscheinlich noch ändern wird.
-:::
-
-## Plattform-Unterstützung
-
-Mit dem Ansatz, eine verwaltete API zu verwenden, müssen sich die Nutzer keine Gedanken mehr über rotierende Proxys, Skalierungsprobleme und Ausfälle machen. Außerdem wird eine breite Palette von Plattformen unterstützt. Sie können problemlos in NodeJS, Python (ohne Requests oder Beautifulsoap), Golang usw. integriert werden. Jede Plattform, die es erlaubt, GET-Anfragen auszuführen, kann so programmiert werden, dass sie Daten von diesem Dienst abruft.
diff --git a/websites/de/apis/facebook.md b/websites/de/apis/facebook.md
deleted file mode 100644
index 4b5ccfa..0000000
--- a/websites/de/apis/facebook.md
+++ /dev/null
@@ -1,28 +0,0 @@
-# Facebook Scraper API
-
-Das Team hinter PHP Scraper arbeitet daran, kommerzielle APIs für verschiedene gängige Anwendungsfälle und Plattformen bereitzustellen. Diese APIs werden nicht selbst gehostet. Sie müssen sich keine Gedanken über rotierende IPs/Proxies machen und einen Headless-Browser wie Puppeteer verwenden. Mit einem einfachen API-Aufruf erhalten Sie alle erforderlichen Informationen. Die Dienste werden auf der Grundlage einer attraktiven, nutzungsabhängigen Gebührenstruktur bereitgestellt.
-
-Für Facebook erwägen wir die Implementierung einer API mit folgendem Umfang.
-
-## Vorgeschlagene unterstützte Endpunkte
-
-- Benutzer: Öffentliches Benutzerprofil
-- Benutzer: Andere soziale Konten
-- Benutzer: Freundesliste
-- Benutzer: Bilder
-- Benutzer: Standortbeiträge
-- Benutzer: Benutzerbeiträge
-- öffentliche Gruppen und private Gruppen mit Schlüssel: Öffentliches Gruppenprofil
-- öffentliche Gruppen und private Gruppen mit Schlüssel: Mitgliederliste
-- öffentliche Gruppen und private Gruppen mit Schlüssel: Bilder
-- öffentliche Gruppen und private Gruppen mit Schlüssel: Standort Beiträge
-- öffentliche Gruppen und private Gruppen mit Schlüssel: Beiträge
-- Beitrag: Öffentliche Beitragsdetails (inkl. Kommentare, Likes, Likers, etc.)
-
-::: tip
-Bitte beachten Sie, dass diese Liste der API-Endpunkte *nicht* endgültig ist und sich wahrscheinlich noch ändern wird.
-:::
-
-## Plattform-Unterstützung
-
-Mit dem Ansatz, eine verwaltete API zu verwenden, müssen sich die Nutzer keine Gedanken mehr über rotierende Proxys, Skalierungsprobleme und Ausfälle machen. Außerdem wird eine breite Palette von Plattformen unterstützt. Sie können problemlos in NodeJS, Python (ohne Requests oder Beautifulsoap), Golang usw. integriert werden. Jede Plattform, die es erlaubt, GET-Anfragen auszuführen, kann so programmiert werden, dass sie Daten von diesem Dienst abruft.
diff --git a/websites/de/apis/instagram.md b/websites/de/apis/instagram.md
deleted file mode 100644
index 69591f4..0000000
--- a/websites/de/apis/instagram.md
+++ /dev/null
@@ -1,34 +0,0 @@
-# Instagram Scraper API
-
-Das Team hinter PHP Scraper arbeitet daran, kommerzielle APIs für verschiedene gängige Anwendungsfälle und Plattformen bereitzustellen. Diese APIs werden nicht selbst gehostet. Sie müssen sich keine Gedanken über rotierende IPs/Proxies machen und einen Headless-Browser wie Puppeteer verwenden. Mit einem einfachen API-Aufruf erhalten Sie alle erforderlichen Informationen. Die Dienste werden auf der Grundlage einer attraktiven, nutzungsabhängigen Gebührenstruktur bereitgestellt.
-
-Für Instagram erwägen wir die Implementierung einer API mit folgendem Umfang.
-
-## Vorgeschlagene unterstützte Endpunkte
-
-- Benutzer: Profil Details
-- Benutzer: Highlights
-- Benutzer: Beiträge
-- Benutzer: Getaggte Beiträge
-- Benutzer: Öffentliche Beiträge
-- Benutzer: Follower
-- Benutzer: Geschichten erhalten
-- Benutzer: Aktueller Status
-- Benutzer: Andere soziale Konten
-- Öffentliche Beiträge: Kommentare
-- Öffentlicher Beitrag: Likers
-- Story-Downloader mit Konvertierung in mp4, mp3, etc.
-- Hashtag-Beiträge
-- Standort-Posts
-- Standort-Suche
-- Details zum Beitrag
-- Verwandte Profile
-- Suche
-
-::: tip
-Bitte beachten Sie, dass diese Liste der API-Endpunkte *nicht* endgültig ist und sich wahrscheinlich noch ändern wird.
-:::
-
-## Plattform-Unterstützung
-
-Mit dem Ansatz, eine verwaltete API zu verwenden, müssen sich die Nutzer keine Gedanken mehr über rotierende Proxys, Skalierungsprobleme und Ausfälle machen. Außerdem wird eine breite Palette von Plattformen unterstützt. Sie können problemlos in NodeJS, Python (ohne Requests oder Beautifulsoap), Golang usw. integriert werden. Jede Plattform, die es erlaubt, GET-Anfragen auszuführen, kann so programmiert werden, dass sie Daten von diesem Dienst abruft.
diff --git a/websites/de/apis/linkedin.md b/websites/de/apis/linkedin.md
deleted file mode 100644
index 7cdbb8a..0000000
--- a/websites/de/apis/linkedin.md
+++ /dev/null
@@ -1,21 +0,0 @@
-# LinkedIn Scraper API
-
-Das Team hinter PHP Scraper arbeitet daran, kommerzielle APIs für verschiedene gängige Anwendungsfälle und Plattformen bereitzustellen. Diese APIs werden nicht selbst gehostet. Sie müssen sich keine Gedanken über rotierende IPs/Proxies machen und einen Headless-Browser wie Puppeteer verwenden. Mit einem einfachen API-Aufruf erhalten Sie alle erforderlichen Informationen. Die Dienste werden auf der Grundlage einer attraktiven, nutzungsabhängigen Gebührenstruktur bereitgestellt.
-
-Für LinkedIn ziehen wir die Implementierung einer API mit folgendem Umfang in Betracht.
-
-## Vorgeschlagene unterstützte Endpunkte
-
-- Benutzer: Profil Details
-- Benutzer: Beiträge
-- Beitrag: Video Downloader und Konverter.
-- Unternehmen: Profil-Details
-- Job-Suche
-
-::: tip
-Bitte beachten Sie, dass diese Liste der API-Endpunkte *nicht* endgültig ist und sich wahrscheinlich noch ändern wird.
-:::
-
-## Plattform-Unterstützung
-
-Mit dem Ansatz, eine verwaltete API zu verwenden, müssen sich die Nutzer keine Gedanken mehr über rotierende Proxys, Skalierungsprobleme und Ausfälle machen. Außerdem wird eine breite Palette von Plattformen unterstützt. Sie können problemlos in NodeJS, Python (ohne Requests oder Beautifulsoap), Golang usw. integriert werden. Jede Plattform, die es erlaubt, GET-Anfragen auszuführen, kann so programmiert werden, dass sie Daten von diesem Dienst abruft.
diff --git a/websites/de/apis/target.md b/websites/de/apis/target.md
deleted file mode 100644
index f7a2ff4..0000000
--- a/websites/de/apis/target.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# Target Scraper API
-
-Das Team hinter PHP Scraper arbeitet daran, kommerzielle APIs für verschiedene gängige Anwendungsfälle und Plattformen bereitzustellen. Diese APIs werden nicht selbst gehostet. Sie müssen sich keine Gedanken über rotierende IPs/Proxies machen und einen Headless-Browser wie Puppeteer verwenden. Mit einem einfachen API-Aufruf erhalten Sie alle erforderlichen Informationen. Die Dienste werden auf der Grundlage einer attraktiven, nutzungsabhängigen Gebührenstruktur bereitgestellt.
-
-Für Target ziehen wir die Implementierung einer API mit folgendem Umfang in Betracht.
-
-## Vorgeschlagene unterstützte Endpunkte
-
-- Produktdetails abrufen
-- Schlüsselwortsuche für Produkte
-
-::: tip
-Bitte beachten Sie, dass diese Liste der API-Endpunkte *nicht* endgültig ist und sich wahrscheinlich noch ändern wird.
-:::
-
-## Plattform-Unterstützung
-
-Mit dem Ansatz, eine verwaltete API zu verwenden, müssen sich die Nutzer keine Gedanken mehr über rotierende Proxys, Skalierungsprobleme und Ausfälle machen. Außerdem wird eine breite Palette von Plattformen unterstützt. Sie können problemlos in NodeJS, Python (ohne Requests oder Beautifulsoap), Golang usw. integriert werden. Jede Plattform, die es erlaubt, GET-Anfragen auszuführen, kann so programmiert werden, dass sie Daten von diesem Dienst abruft.
diff --git a/websites/de/apis/tiktok.md b/websites/de/apis/tiktok.md
deleted file mode 100644
index 98fdb41..0000000
--- a/websites/de/apis/tiktok.md
+++ /dev/null
@@ -1,21 +0,0 @@
-# TikTok Scraper API
-
-Das Team hinter PHP Scraper arbeitet daran, kommerzielle APIs für verschiedene gängige Anwendungsfälle und Plattformen bereitzustellen. Diese APIs werden nicht selbst gehostet. Sie müssen sich keine Gedanken über rotierende IPs/Proxies machen und einen Headless-Browser wie Puppeteer verwenden. Mit einem einfachen API-Aufruf erhalten Sie alle erforderlichen Informationen. Die Dienste werden auf der Grundlage einer attraktiven, nutzungsabhängigen Gebührenstruktur bereitgestellt.
-
-Für TikTok erwägen wir die Implementierung einer API mit dem folgenden Umfang.
-
-## Vorgeschlagene unterstützte Endpunkte
-
-- Suche nach Tag
-- Benutzer: Öffentliche Profildetails
-- Benutzer: Andere soziale Konten
-- Video-Details
-- Video Download mit Konvertierung in mp4, mp3, etc. und ohne Wasserzeichen
-
-::: tip
-Bitte beachten Sie, dass diese Liste der API-Endpunkte *nicht* endgültig ist und sich wahrscheinlich noch ändern wird.
-:::
-
-## Plattform-Unterstützung
-
-Mit dem Ansatz, eine verwaltete API zu verwenden, müssen sich die Nutzer keine Gedanken mehr über rotierende Proxys, Skalierungsprobleme und Ausfälle machen. Außerdem wird eine breite Palette von Plattformen unterstützt. Sie können problemlos in NodeJS, Python (ohne Requests oder Beautifulsoap), Golang usw. integriert werden. Jede Plattform, die es erlaubt, GET-Anfragen auszuführen, kann so programmiert werden, dass sie Daten von diesem Dienst abruft.
diff --git a/websites/de/apis/walmart.md b/websites/de/apis/walmart.md
deleted file mode 100644
index 6a6838d..0000000
--- a/websites/de/apis/walmart.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# Walmart Scraper API
-
-Das Team hinter PHP Scraper arbeitet daran, kommerzielle APIs für verschiedene gängige Anwendungsfälle und Plattformen bereitzustellen. Diese APIs werden nicht selbst gehostet. Sie müssen sich keine Gedanken über rotierende IPs/Proxies machen und einen Headless-Browser wie Puppeteer verwenden. Mit einem einfachen API-Aufruf erhalten Sie alle erforderlichen Informationen. Die Dienste werden auf der Grundlage einer attraktiven, nutzungsabhängigen Gebührenstruktur bereitgestellt.
-
-Für Walmart ziehen wir die Implementierung einer API mit folgendem Umfang in Betracht.
-
-## Vorgeschlagene unterstützte Endpunkte
-
-- Produktdetails abrufen
-- Schlüsselwortsuche für Produkte
-
-::: tip
-Bitte beachten Sie, dass diese Liste der API-Endpunkte *nicht* endgültig ist und sich wahrscheinlich noch ändern wird.
-:::
-
-## Plattform-Unterstützung
-
-Mit dem Ansatz, eine verwaltete API zu verwenden, müssen sich die Nutzer keine Gedanken mehr über rotierende Proxys, Skalierungsprobleme und Ausfälle machen. Außerdem wird eine breite Palette von Plattformen unterstützt. Sie können problemlos in NodeJS, Python (ohne Requests oder Beautifulsoap), Golang usw. integriert werden. Jede Plattform, die es erlaubt, GET-Anfragen auszuführen, kann so programmiert werden, dass sie Daten von diesem Dienst abruft.
diff --git a/websites/de/apis/zalando.md b/websites/de/apis/zalando.md
deleted file mode 100644
index eb7f74c..0000000
--- a/websites/de/apis/zalando.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# Zalando Scraper API
-
-Das Team hinter PHP Scraper arbeitet daran, kommerzielle APIs für verschiedene gängige Anwendungsfälle und Plattformen bereitzustellen. Diese APIs werden nicht selbst gehostet. Sie müssen sich keine Gedanken über rotierende IPs/Proxies machen und einen Headless-Browser wie Puppeteer verwenden. Mit einem einfachen API-Aufruf erhalten Sie alle erforderlichen Informationen. Die Dienste werden auf der Grundlage einer attraktiven, nutzungsabhängigen Gebührenstruktur bereitgestellt.
-
-Für Zalando erwägen wir die Implementierung einer API mit folgendem Umfang.
-
-## Vorgeschlagene unterstützte Endpunkte
-
-- Produktdetails abrufen
-- Schlüsselwortsuche für Produkte
-
-::: tip
-Bitte beachten Sie, dass diese Liste der API-Endpunkte *nicht* endgültig ist und sich wahrscheinlich noch ändern wird.
-:::
-
-## Plattform-Unterstützung
-
-Mit dem Ansatz, eine verwaltete API zu verwenden, müssen sich die Nutzer keine Gedanken mehr über rotierende Proxys, Skalierungsprobleme und Ausfälle machen. Außerdem wird eine breite Palette von Plattformen unterstützt. Sie können problemlos in NodeJS, Python (ohne Requests oder Beautifulsoap), Golang usw. integriert werden. Jede Plattform, die es erlaubt, GET-Anfragen auszuführen, kann so programmiert werden, dass sie Daten von diesem Dienst abruft.
diff --git a/websites/de/examples/extract-keywords.md b/websites/de/examples/extract-keywords.md
deleted file mode 100644
index 68472c5..0000000
--- a/websites/de/examples/extract-keywords.md
+++ /dev/null
@@ -1,122 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Extract%20Keywords&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Keywords Extrahieren
-
-Während es oft ausreicht, Inhalte zu scrapen, müssen Sie manchmal wichtige Begriffe und Phrasen (Keywords) aus diesen Inhalten extrahieren. PHPScraper ermöglicht es Ihnen, die Keywords der Website direkt zu extrahieren. Hierfür verwendet er:
-
-- den Titel der Website,
-- die Meta-Tags,
-- alle Überschriften,
-- die Absätze auf der Seite,
-- Link-Anker und Link-Titel sowie
-- Titelattribute bei Bildern
-
-Auch wenn diese Schlüsselwörter extrahiert werden, bedeutet dies nicht, dass die Seite tatsächlich für diese Schlüsselwörter rangiert. Die endgültige Entscheidung darüber, für welche Schlüsselwörter eine Webseite rangiert, liegt bei der Suchmaschine.
-
-Das folgende Beispiel gibt eine Liste aller aus der Webseite extrahierten Keywords zurück:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigation zur Testseite.
-// Diese enthält 3 Absätze aus dem englischen Wikipedia-Artikel zu "lorem ipsum".
-$web->go('https://test-pages.phpscraper.de/content/keywords.html');
-
-// Überprüfen der Anzahl der Schlüsselwörter.
-$keywords = $web->contentKeywords;
-echo "Diese Seite enthält mindestens" . count($keywords) . " Schlüsselwörter/Phrasen.\n\n";
-
-// Schleife durch die Schlüsselwörter
-foreach ($keywords as $keyword) {
- echo " - " . $keyword . "\n";
-}
-
-/**
- * Ausgegeben wird:
- *
- * Diese Seite enthält mindestens 40 Schlüsselwörter/Phrasen.
- *
- * [...]
- * - graphic
- * - improper latin
- * - introduced
- * - keyword extraction tests
- * - letraset transfer sheets
- * - lorem ipsum
- * - lorem ipsum php rake library lorem ipsum
- * - lorem ipsum text
- * - make
- * - malorum
- * - microsoft word
- * - mid-1980s
- * - nonsensical
- * - page
- * - paragraphs
- * - philosopher cicero
- * - php rake library
- * - popular word processors including pages
- * - popularized
- * - removed
- * - roman statesman
- * - source
- * [...]
- */
-```
-
-::: tip Tipp
-Die Standardsprache (Gebietsschema) hierfür ist "en_US". Andere Sprachen, wie Deutsch, können als Parameter übergeben werden. Dies funktioniert derzeit nur für eine Auswahl von Sprachen. Weitere Informationen finden Sie in dieser [list](https://github.com/Donatello-za/rake-php-plus#currently-supported-languages).
-:::
-
-
-## Bewertung von Schlüsselwörtern
-
-Nicht jedes Keyword hat in den Ranking-Algorithmen der Suchmaschinen das gleiche Gewicht. Ein Mix aus verschiedenen Faktoren und SEO-Signalen entscheidet über die Gewichtung, die eine Suchmaschine einem Wort zuweist. Häufigkeit der Wörter, Länge der Texte und Variationen wie Synonyme können zu einer unterschiedlichen Gewichtung führen.
-
-PHPScraper ermöglicht es Ihnen, einen Hinweis auf die Gewichtung der Keywords in Form von Scores zu erhalten:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigation zur Testseite.
-// Diese enthält 3 Absätze aus dem englischen Wikipedia-Artikel zu "lorem ipsum".
-$web->go('https://test-pages.phpscraper.de/content/keywords.html');
-
-// Überprüfen der Anzahl der Schlüsselwörter.
-$keywords = $web->contentKeywordsWithScores;
-echo "Diese Seite enthält mindestens " . count($keywords) . " Schlüsselwörter/Phrasen.\n\n";
-
-// Schleife durch die Schlüsselwörter
-foreach ($keywords as $keyword => $score) {
- echo sprintf(" - %s (%s)\n", $keyword, $score);
-}
-
-/**
- * Ausgegeben wird:
- *
- * Diese Seite enthält mindestens 40 Schlüsselwörter/Phrasen.
- *
- * [...]
- * - 1960s (1.0)
- * - added (1.0)
- * - adopted lorem ipsum (11.0)
- * - advertisements (1.0)
- * - aldus employed (4.0)
- * - corrupted version (4.0)
- * - graphic (1.0)
- * - improper latin (4.0)
- * - introduced (1.0)
- * - keyword extraction tests (9.0)
- * - test (1.0)
- * - microsoft word (5.3333333333333)
- * - english wikipedia (4.0)
- * - lorem ipsum (8.0)
- * - lorem ipsum text (11.0)
- * [...]
- */
-```
-
-::: tip Tipp
-Die PHP-Funktionen [similar_text](https://www.php.net/manual/en/function.similar-text.php) und [levenshtein](https://www.php.net/manual/en/function.levenshtein.php) können Ihnen helfen, ähnliche Schlüsselwörter sowie Tippfehler-Varianten von Schlüsselwörtern zu identifizieren und zusammenzuführen. [Keyword Merge](https://github.com/spekulatius/keyword-merge) ist ein Composer-Paket, das beim Aussortieren ähnlicher Schlüsselwörter hilft.
-:::
diff --git a/websites/de/examples/headings.md b/websites/de/examples/headings.md
deleted file mode 100644
index 3fbf9fb..0000000
--- a/websites/de/examples/headings.md
+++ /dev/null
@@ -1,124 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Headings&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrapen von Überschriften
-
-Überschriften können nützlich sein, um sich einen Überblick über den Inhalt einer Website zu verschaffen. Das folgende Beispiel zeigt, wie man scrapen kann:
-
- - Eine einzelne Überschrift
- - Alle Überschriften einer bestimmten Ebene (z.B. `
`)
- - Alle Überschriften auf einer Seite
-
-
-## Einzelne Überschrift Scrapen
-
-Das Einscannen einer einzelnen Überschrift ist einfach und kann anhand dieses Beispiels durchgeführt werden:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese enthält:
- *
- * Outline Test
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-// Ausgeben der H1-Überschrift
-echo $web->h1[0]; // "Outline Test"
-```
-
-::: tip
-Der [Website-Titel](/de/examples/scrape-website-title.html) und die Überschrift 1 (`
`) können unterschiedlich sein. Stellen Sie sicher, dass Sie die richtige abrufen.
-:::
-
-
-## Rubriken nach Ebene
-
-Es kann Fälle geben, die Überschriften einer bestimmten Ebene abgerufen werden sollen. Das folgende Beispiel zeigt, wie dies möglich ist:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese enthält:
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-/**
- * Gibt die h3-Überschriften zurück:
- *
- * [
- * 'Example 1',
- * 'Example 2',
- * 'Example 3'
- * ]
- */
-$web->h3;
-```
-
-Wenn keine Überschriften gefunden werden, bleibt das Feld leer.
-
-
-## Alle Überschriften auf einer Seite
-
-Um auf alle Rubriken einer Seite zuzugreifen, können Sie die verschiedenen Ebenen von 1 bis 6 anwählen. Alternativ können Sie auch alle auf einmal aufrufen:
-
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese Seite enthält:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-/**
- * $headings enthält jetzt:
- *
- * [
- * [
- * 'We are testing here!'
- * ],
- * [
- * 'Examples'
- * ],
- * [
- * 'Example 1',
- * 'Example 2',
- * 'Example 3',
- * ],
- * [],
- * [],
- * []
- * ]
- */
-$web->headings;
-```
-
-Wie Sie sehen können, enthält dies keine Informationen über die Struktur der Überschriften. Es geht nur darum zu wissen, welche Überschriften vorhanden sind. Wenn Sie eine [Gliederung](/de/examples/outline.html) haben möchten, müssen Sie die entsprechenden Methoden verwenden.
diff --git a/websites/de/examples/lists.md b/websites/de/examples/lists.md
deleted file mode 100644
index 4c02716..0000000
--- a/websites/de/examples/lists.md
+++ /dev/null
@@ -1,71 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Lists&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Listen Scrapen
-
-Das Scraping von Listen folgt einem ähnlichen Ansatz wie anderes Scraping mit PHPScraper:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese Seite enthält:
- *
- *
)
- *
- * [
- * "type" => "ul",
- * "children" => ... // Liste der ChildNodes
- * "children_plain" =>
- * [
- * "Unordered list item 1"
- * "Unordered list item 2"
- * "Unordered list item with HTML"
- * ]
- * ]
- */
-var_dump($web->unorderedLists);
-
-
-/**
- * Nur geordnete Listen ()
- *
- * [
- * "type" => "ul",
- * "children" => ... // Liste der ChildNodes
- * "children_plain" =>
- * [
- * "Ordered list item 1"
- * "Ordered list item 2"
- * "Ordered list item with HTML"
- * ]
- * ]
- */
-var_dump($web->orderedLists);
-
-
-// Beide Listen zusammen (wie oben)
-var_dump($web->lists);
-```
-
-::: warning Verschachtelte Listen
-Im Moment werden verschachtelte Listen nicht gut verarbeitet. Verschachtelte Listen werden als `children` in das Ergebnis aufgenommen, um eine weitere Verarbeitung zu ermöglichen.
-:::
diff --git a/websites/de/examples/navigation.md b/websites/de/examples/navigation.md
deleted file mode 100644
index f6f9954..0000000
--- a/websites/de/examples/navigation.md
+++ /dev/null
@@ -1,59 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Navigate%20while%20Scraping&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Navigation
-
-Obwohl PHPScraper hauptsächlich dazu gedacht ist, Webseiten zu analysieren und Informationen zu sammeln, kannst du es auch benutzen, um auf Webseiten zu navigieren. Im Folgenden finden Sie Beispiele, wie Sie auf einer Website *surfen* können.
-
-
-## Navigation über URLs
-
-Sie können zu jeder URL navigieren. Diese URLs stammen normalerweise aus den [geparsten Links](/de/examples/scrape-links.html).
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Wir beginnen mit der Testseite Nr. 1.
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-// Ausgaben des Titel, um zu sehen, ob wir tatsächlich auf der richtigen Seite sind...
-echo $web->h1[0]; // 'Page #1'
-
-
-// Wir navigieren zur Testseite #2 unter Verwendung der absoluten URL.
-$web->clickLink('https://test-pages.phpscraper.de/navigation/2.html');
-
-// Ausgaben des Titel, um zu sehen, ob wir tatsächlich auf der richtigen Seite sind...
-echo $web->h1[0]; // 'Page #2'
-```
-
-
-## Navigation mit Ankertexten
-
-Auf einer Website können Sie auf Links *klicken*, indem Sie deren Ankertexte verwenden:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Wir beginnen mit der Testseite Nr. 1.
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-/**
- * Diese Seite enthält:
- *
- * 2 relative
- */
-
-// Ausgaben des Titel, um zu sehen, ob wir tatsächlich auf der richtigen Seite sind...
-echo $web->h1[0]; // 'Page #1'
-
-
-// Wir navigieren zur Testseite #2, indem wir den Text verwenden, der auf der Seite steht.
-$web->clickLink('2 relative');
-
-// Ausgaben des Titel, um zu sehen, ob wir tatsächlich auf der richtigen Seite sind...
-echo $web->h1[0]; // 'Page #1'
-```
-
-Diese Grundfunktionalität sollte es Ihnen ermöglichen, auf Websites zu navigieren.
diff --git a/websites/de/examples/outline.md b/websites/de/examples/outline.md
deleted file mode 100644
index 8f93590..0000000
--- a/websites/de/examples/outline.md
+++ /dev/null
@@ -1,215 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scrape%20Content%20Outline&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Gliederung Extrahieren
-
-Auch wenn Sie nur auf die [`Überschriften`](/de/examples/headings.html) zugreifen möchten, um z.B. die Anzahl oder Länge der Überschriften zu verarbeiten, reicht dies nicht immer aus. In einigen Fällen müssen Sie vielleicht die tatsächliche Struktur des Inhalts ermitteln. Für diese Anwendungsfälle sollten Sie eine der folgenden Methoden in Betracht ziehen:
-
- - `outline` funktioniert ähnlich wie die zuvor erwähnte Methode `headings`. Sie gibt ebenfalls alle Überschriften zurück, behält aber die Struktur des Originaldokuments bei und liefert nur die Überschriftenebenen (z.B. `h1`) mit der Ausgabe.
-
- - Die Methode `outlineWithParagraphs` funktioniert ähnlich wie `outline`, mit dem Unterschied, dass dieser Aufruf auch die Absätze enthält.
-
- - `cleanOutlineWithParagraphs` funktioniert ähnlich wie `outlineWithParagraphs`, mit dem Unterschied, dass alle leeren HTML-Tags entfernt werden.
-
-Die folgenden Beispiele sollen helfen, die Funktionalität besser zu verstehen. Es sind spezielle Methoden für die [Schlüsselwort-Extraktion](/de/examples/extract-keywords.html) verfügbar.
-
-
-## Extrahieren der Gliederung
-
-Die Gliederung des Inhalts ermöglicht es Ihnen, einen Index des Dokuments zu erstellen. Im folgenden Beispiel wird eine Markdown-Version der Überschriften des angeforderten Dokuments erstellt:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese Seite enthält:
- *
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-
-$content = $web->outlineWithParagraphs;
-/**
- * $content now contains:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "p",
- * "content" => "This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example."
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "p",
- * "content" => "There are numerous examples on the website. Please check them out to get more context on how scraping works."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be an example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be the second example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be another example."
- * ], [
- * "tag" => "p",
- * "content" => ""
- * ]
- * ]
- */
-```
-
-
-## Extrahieren der bereinigten Gliederung mit Absätzen
-
-Die folgende Methode funktioniert ähnlich wie `outlineWithParagraphs`, aber diese enthält keine leeren Überschriften oder Absätze als Teil des zurückgegebenen Arrays:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese Seite enthält:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-
-$content = $web->cleanOutlineWithParagraphs;
-/**
- * $content enthält jetzt:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "p",
- * "content" => "This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example."
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "p",
- * "content" => "There are numerous examples on the website. Please check them out to get more context on how scraping works."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be an example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be the second example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be another example."
- * ]
- * ]
- */
-```
diff --git a/websites/de/examples/paragraphs.md b/websites/de/examples/paragraphs.md
deleted file mode 100644
index 3911eed..0000000
--- a/websites/de/examples/paragraphs.md
+++ /dev/null
@@ -1,64 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Content&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrapen von Text
-
-Das Scraping von Inhalten, vor allem von Absätzen, kann mit PHP Scraper leicht durchgeführt werden. Es gibt eine spezielle Methode, um auf die Absätze (`
`) einer Website zuzugreifen. Die folgenden Beispiele zeigen, wie man auf den Inhalt/Text einer Website zugreifen kann.
-
-
-## Alle Absätze abrufen
-
-Das folgende Beispiel gibt eine Liste aller Absätze (`
`-Tags) auf der Website zurück:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigation zur Testseite. Diese enthält 6 "lorem ipsum"-Absätze:
-$web->go('https://test-pages.phpscraper.de/content/paragraphs.html');
-
-// Überprüfen der Anzahl der Absätze:
-echo "Diese Seite enthält " . count($web->paragraphs) . " Paragraphen.\n\n";
-
-// Schleife durch die Absätze:
-foreach ($web->paragraphs as $paragraph) {
- echo " - " . $paragraph . "\n";
-}
-
-/**
- * Ausgegeben wird:
- *
- * Diese Seite enthält 6 Absätze.
- *
- * - Maecenas eget ex sit amet urna porta fermentum at ut dui. Praesent lectus arcu, hendrerit sed mi vel, commodo lacinia velit. Nullam ac velit quis ante tristique scelerisque quis non metus. Pellentesque non aliquam elit, in tincidunt purus. Vestibulum fringilla cursus risus, eget ornare dolor feugiat vitae. Sed non porta lorem, eget ornare diam. Sed quam est, eleifend porttitor imperdiet sit amet, ultricies vel ipsum. Pellentesque mauris mauris, fermentum pretium ex quis, viverra mattis est. Donec laoreet sem nec arcu rhoncus lobortis. Duis id orci vel enim interdum aliquam. Integer eu ex ligula. Ut mattis nisi non malesuada ornare. In elit ligula, ultricies a aliquet eget, dictum sit amet neque. Quisque nulla sem, aliquam id molestie iaculis, consequat at augue. Nullam sollicitudin finibus eros in venenatis. Donec semper sagittis ipsum, et rhoncus magna ultricies eu.
-
- * - Quisque sed dolor ut nunc accumsan lacinia. Suspendisse vel eros faucibus massa feugiat tristique. Nullam vitae scelerisque felis, malesuada hendrerit felis. Quisque eleifend mi lorem, vitae elementum dolor bibendum et. Etiam et faucibus augue. Pellentesque viverra sagittis consequat. Nulla a mollis ex. Sed vel nisl mauris. Nulla consequat dui sed pulvinar interdum. Integer vehicula molestie quam non fringilla. Duis auctor sem ut purus fringilla, in lacinia dui finibus. Nulla rhoncus semper velit, eget semper tellus suscipit eget. Vestibulum massa tellus, tristique sit amet dolor et, ullamcorper porta turpis. Vivamus eget magna lacinia, pretium sem sed, gravida libero.
-
- * - Ut at nunc laoreet, vestibulum mauris in, volutpat magna. Aliquam sodales orci finibus porta convallis. Vestibulum sollicitudin felis a sem consequat luctus. Sed laoreet porta quam, non pharetra massa mattis semper. Phasellus aliquet tortor ut felis scelerisque, non dapibus justo tincidunt. Donec eu pulvinar nisi, sit amet elementum massa. Nulla in odio est. In neque ligula, tristique rhoncus orci eu, egestas ullamcorper est. Integer rhoncus vel quam vel placerat. In nec metus pellentesque elit accumsan molestie eu posuere odio. Sed at eros nec turpis vestibulum eleifend vel in erat. Etiam vel metus faucibus, tempus enim nec, elementum arcu. Ut nec blandit risus. Nam sapien nunc, tristique sit amet facilisis non, maximus a nulla. Pellentesque vel posuere libero.
-
- * - Morbi volutpat purus odio, vitae scelerisque diam consectetur sed. Cras turpis leo, hendrerit in tempus et, convallis in nibh. Mauris molestie facilisis odio, ac egestas erat ultrices pellentesque. Donec interdum leo quis ipsum sagittis venenatis. Etiam scelerisque mi at metus ullamcorper, vitae tristique est tincidunt. Vestibulum ut congue urna, eu sagittis quam. Phasellus eget arcu sapien. In hac habitasse platea dictumst. Morbi ultrices, felis in faucibus ornare, libero augue scelerisque urna, et feugiat nisl est ut velit. Phasellus felis quam, egestas a faucibus nec, dictum eget enim. In tempor a lacus id facilisis.
-
- * - Donec bibendum finibus neque quis viverra. Ut ut nulla venenatis, accumsan purus nec, ullamcorper nisi. Nulla bibendum dui sit amet velit venenatis, eget viverra nibh accumsan. Fusce pharetra, sem eu mattis varius, massa leo eleifend lectus, quis tempor elit ipsum sit amet lorem. Fusce viverra dictum tortor non sodales. Phasellus at lectus quis arcu finibus imperdiet sed eleifend nulla. Donec blandit egestas nibh ac euismod. Curabitur ac pretium eros.
-
- * - Duis pharetra magna at dolor scelerisque, nec luctus ex pretium. Suspendisse a ante lectus. Donec vehicula condimentum turpis, in hendrerit dui suscipit non. Nullam a ultricies felis. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Praesent aliquet varius mauris nec pretium. Vivamus convallis tincidunt nisi, eget scelerisque dolor facilisis vitae. Pellentesque purus neque, sollicitudin sit amet mauris id, posuere posuere mi. Etiam vitae urna vitae turpis volutpat consectetur. Quisque ultrices, ex dapibus hendrerit convallis, diam massa suscipit diam, vulputate pharetra mi orci at massa. Aliquam vel urna tempor, congue justo id, pulvinar lorem. Nulla mattis vitae justo sed molestie. Nunc fermentum fringilla nibh, id fermentum nulla. Sed tincidunt ipsum id est efficitur, molestie aliquet lacus hendrerit. Fusce et nisl eros.
- */
-```
-
-
-## Scrapen des ersten Absatzes
-
-Das Scraping des ersten Absatzes der Website kann durch Zugriff auf das erste Element des Arrays (Index 0) erfolgen.
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/content/paragraphs.html');
-
-echo $web->paragraphs[0];
-/**
- * Gibt den ersten Absatz aus:
- *
- * Maecenas eget ex sit amet urna porta fermentum at ut dui. Praesent lectus arcu, hendrerit sed mi vel, commodo lacinia velit. Nullam ac velit quis ante tristique scelerisque quis non metus. Pellentesque non aliquam elit, in tincidunt purus. Vestibulum fringilla cursus risus, eget ornare dolor feugiat vitae. Sed non porta lorem, eget ornare diam. Sed quam est, eleifend porttitor imperdiet sit amet, ultricies vel ipsum. Pellentesque mauris mauris, fermentum pretium ex quis, viverra mattis est. Donec laoreet sem nec arcu rhoncus lobortis. Duis id orci vel enim interdum aliquam. Integer eu ex ligula. Ut mattis nisi non malesuada ornare. In elit ligula, ultricies a aliquet eget, dictum sit amet neque. Quisque nulla sem, aliquam id molestie iaculis, consequat at augue. Nullam sollicitudin finibus eros in venenatis. Donec semper sagittis ipsum, et rhoncus magna ultricies eu.
- */
-```
-
-Leere p-tags würden zu leeren Strings im zurückgegebenen Array führen. Um dies zu vermeiden, können Sie stattdessen `$web->cleanParagraphs` aufrufen. Dadurch werden leere Absätze herausgefiltert und nur solche mit Inhalt zurückgegeben. Um auf den ersten Absatz mit Inhalt zuzugreifen, verwenden Sie `$web->cleanParagraphs[0]`.
diff --git a/websites/de/examples/scrape-header-tags.md b/websites/de/examples/scrape-header-tags.md
deleted file mode 100644
index a82f4d8..0000000
--- a/websites/de/examples/scrape-header-tags.md
+++ /dev/null
@@ -1,153 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Header%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Header Tags Scrapen
-
-Die Header-Tags enthalten oft nützliche Informationen über eine Webseite und darüber, wie sie sich in die Gesamtstruktur der Website einfügt, zu der sie gehört. Die folgenden Beispiele zeigen, wie man auf bestimmte Informationen aus dem `
` zugreift und Sammlungen um diese herum erstellt.
-
-
-## Charset / Zeichensatz
-
-Um auf den definierten Zeichensatz zuzugreifen, können Sie die folgende Methode verwenden:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese enthält:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Gibt den charset aus:
-echo $web->charset; // "utf-8"
-```
-
-
-## Viewport
-
-In einigen Fällen, wie z.B. dem Viewport und den Meta-Keywords, stellt die Zeichenkette ein Array dar und wird als solches angegeben:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese enthält:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Gibt den Viewport als Array zurück. Es beinhaltet:
- *
- * [
- * 'width=device-width',
- * 'initial-scale=1',
- * 'shrink-to-fit=no',
- * 'maximum-scale=1',
- * 'user-scalable=no'
- * ],
- */
-var_dump($web->viewport);
-```
-
-Wenn Sie auf die ursprüngliche Reihenfolge zugreifen müssen, können Sie diese mit `viewportString` abrufen:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Gibt den Viewport als String zurück:
- *
- * "width=device-width, initial-scale=1, shrink-to-fit=no, maximum-scale=1, user-scalable=no"
- */
-echo $web->viewportString;
-```
-
-
-## Canonical URL
-
-Auf die kanonische URL kann, sofern vorhanden, wie im folgenden Beispiel gezeigt, zugegriffen werden:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese enthält:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-// Ausgabe der canonical URL
-echo $web->canonical; // "https://test-pages.phpscraper.de/navigation/2.html"
-```
-
-::: tip Tipp
-Wenn kein kanonischer Link gesetzt ist, gibt die Methode `null` zurück.
-:::
-
-
-## Content-Type
-
-Um auf den Inhaltstyp zuzugreifen, können Sie die folgenden Funktionen nutzen:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese enthält:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Ausgabe des contentType
-echo $web->contentType; // "text/html; charset=utf-8"
-```
-
-
-## CSFR Token
-
-Die CSFR-Token-Methode geht davon aus, dass das Token in einem Meta-Tag mit dem Namen "csrf-token" gespeichert ist. Dies ist der Standard für Laravel. Sie können mit folgendem Code darauf zugreifen:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese enthält:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Gibt den csrfToken aus:
-echo $web->csrfToken; // "token"
-```
-
-
-## Kombinierte Kopfzeilen-Tags
-
-Wenn Sie auf alle oben genannten Methoden zugreifen wollen, verwenden Sie die Methode `headers`. Sie ist definiert als:
-
-```php
-/**
- * @return array
- */
-public function headers()
-{
- return [
- 'charset' => $this->charset(),
- 'contentType' => $this->contentType(),
- 'viewport' => $this->viewport(),
- 'canonical' => $this->canonical(),
- 'csrfToken' => $this->csrfToken(),
- ];
-}
-```
-
-Weitere Informationen zum Zugriff auf die [Meta-Tags](/de/examples/scrape-meta-tags.html).
diff --git a/websites/de/examples/scrape-images.md b/websites/de/examples/scrape-images.md
deleted file mode 100644
index 5186730..0000000
--- a/websites/de/examples/scrape-images.md
+++ /dev/null
@@ -1,79 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Images&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Bilder Scrapen
-
-Sie fragen sich vielleicht, wie man mit PHPScraper Fotos, Bilder und andere Grafiken von einer Website scrapen kann. Wie bei anderen Funktionen auch, folgt das Scraping von Bildern & Fotos von einer Website einem ähnlichen Ansatz. Alle Grafiken wie Bilder, Fotos und Infografiken können zusammen mit Details wie Tag-Attributen oder nur als URL-Liste ausgelesen und analysiert werden.
-
-
-## Bild-URLs Scrapen
-
-Das folgende Beispiel durchsucht eine Webseite nach Bildern und gibt absolute Bild-URLs als Array zurück.
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese Seite enthält zwei Bilder:
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * [
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- *
- * @note
- *
- * Die Image URL ist doppelt enthalten, weil die Seite zweimal das gleiche Bild enthält:
- * Einmal mit einem relativen Pfad und einmal mit einem absoluten Pfad.
- * Die relativen Pfade werden standardmäßig in absolute Pfade aufgelöst.
- */
-var_dump($web->images);
-```
-
-::: tip Tipp
-Wenn keine Bilder gefunden werden, bleibt das Feld leer. Bilder können mit `$web->fetchAsset(...)` heruntergeladen werden.
-:::
-
-
-## Bild URLs mit Details Scrapen
-
-Wenn Sie mehr Details benötigen, können Sie mit den folgenden Anfragen auf die Attribute des Bild-Tags zugreifen:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'absolute path',
- * 'width' => null,
- * 'height' => null,
- * ],
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'relative path',
- * 'width' => null,
- * 'height' => null,
- * ]
- */
-var_dump($web->imagesWithDetails);
-```
-
-::: tip SEO
-Der `alt`-Text (mit den [Schlüsselwörtern des Inhalts](/de/examples/extract-keywords.html)) wird von Suchmaschinen für bildbasierte Suchen verwendet. Achten Sie darauf, ihn immer zu definieren.
-:::
-
-
-## Attribute Scrapen: Alt-Text, Breite und Höhe
-
-Die Attribute für "Alt", "Breite" und "Höhe" sind im ausführlichen Datensatz enthalten.
-
-Wenn Sie mehr Daten benötigen, müssen Sie entweder die Bibliothek erweitern oder ein Problem zur Prüfung einreichen.
diff --git a/websites/de/examples/scrape-links.md b/websites/de/examples/scrape-links.md
deleted file mode 100644
index 266e0fe..0000000
--- a/websites/de/examples/scrape-links.md
+++ /dev/null
@@ -1,120 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Links&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Links Scrapen
-
-Das Scraping von Links funktioniert sehr ähnlich wie [image scraping](/de/examples/scrape-images.html). Sie können sowohl eine Liste von URLs ohne zusätzliche Informationen als auch eine detaillierte Liste mit `rel`, `target` und anderen Attributen abrufen.
-
-
-## Einfache Link-Liste
-
-Das folgende Beispiel analysiert eine Webseite nach Links und gibt ein Array mit absoluten URLs zurück:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese enthält 6 Links zu placekitten.com mit unterschiedlichen Attributen:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/links/target.html');
-
-// Geben Sie die Anzahl der Links aus.
-echo "Diese Seite enthält " . count($web->links) . " Links.\n\n";
-
-// Schleife durch die Links
-foreach ($web->links as $link) {
- echo " - " . $link . "\n";
-}
-
-/**
- * Kombiniert wird dies ausgegeben als:
- *
- * Diese Seite enthält 6 Links.
- *
- * - https://placekitten.com/408/287
- * - https://placekitten.com/444/333
- * - https://placekitten.com/444/321
- * - https://placekitten.com/408/287
- * - https://placekitten.com/444/333
- * - https://placekitten.com/444/321
- */
-```
-
-Wenn die Seite keine Links enthalten soll, wird ein leeres Array zurückgegeben.
-
-
-## Links mit Details
-
-Wenn Sie weitere Details benötigen, können Sie diese auf ähnliche Weise wie bei den Bildern abrufen. Nachstehend finden Sie ein Beispiel für den Zugriff auf die detaillierten Daten des ersten Links auf der Seite:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese Seite enthält eine Reihe von Links mit unterschiedlichen rel-Attributen. Um Platz zu sparen, wird nur der erste Link angezeigt:
- *
- * external kitten
- */
-$web->go('https://test-pages.phpscraper.de/links/rel.html');
-
-// Ermittelt den ersten Link auf der Seite.
-$firstLink = $web->linksWithDetails[0];
-
-/**
- * $firstLink enthält jetzt:
- *
- * [
- * 'url' => 'https://placekitten.com/432/287',
- * 'protocol' => 'https',
- * 'text' => 'external kitten',
- * 'title' => null,
- * 'target' => null,
- * 'rel' => 'nofollow',
- * 'isNofollow' => true,
- * 'isUGC' => false,
- * 'isNoopener' => false,
- * 'isNoreferrer' => false,
- * ]
- */
-```
-
-Wenn Sie mehr Daten benötigen, müssen Sie entweder die Bibliothek erweitern oder eine Ausgabe zur Prüfung einreichen.
-
-
-## Interne Links und externe Links
-
-PHPScraper erlaubt es alle, interne oder externe Links zurückzugeben. Das folgende Beispiel demonstriert `internalLinks` sowie `externalLinks`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigation zur Testseite.
-$web->go('https://test-pages.phpscraper.de/links/base-href.html');
-
-// Abrufen der Liste der internen Links (im Beispiel ist ein Bild verlinkt)
-var_dump($web->internalLinks);
-/**
- * [
- * 'https://test-pages.phpscraper.de/assets/cat.jpg'
- * ]
- */
-
-// Abrufen der Liste der externen Links
-var_dump($web->externalLinks);
-/**
- * [
- * 'https://placekitten.com/408/287'
- * ]
- */
-```
diff --git a/websites/de/examples/scrape-meta-tags.md b/websites/de/examples/scrape-meta-tags.md
deleted file mode 100644
index 2dcbda6..0000000
--- a/websites/de/examples/scrape-meta-tags.md
+++ /dev/null
@@ -1,114 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Meta%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Meta Tags Scrapen
-
-Der Zugriff auf die Meta-Informationen erfolgt nach einem ähnlichen Muster wie bei den zuvor gezeigten [header-tags](/de/examples/scrape-header-tags.html). Nachfolgend finden Sie eine Reihe von Beispielen:
-
-
-## Meta Autor, Beschreibung und Bild
-
-Das folgende Beispiel zeigt die Extraktion von drei Attributen:
-
-- der Meta-Autor,
-- die Meta-Beschreibung und
-- die Meta Image URL
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese enthält:
- *
- *
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Abrufen der Informationen:
-echo $web->author; // "Lorem ipsum"
-echo $web->description; // "Lorem ipsum dolor etc."
-echo $web->image; // "https://test-pages.phpscraper.de/assets/cat.jpg"
-```
-
-
-## Meta-Keywords
-
-Der Meta-Tag keywords ist natürlich ein Array und wird zu Ihrer Bequemlichkeit aufgeteilt:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese enthält:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-// Auslesen der Schlüsselwörter als Array
-var_dump($web->keywords); // ['one', 'two', 'three']
-```
-
-Alternatively, you can access the original keyword string:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-// Ausgabe der Schlüsselwörter als String
-echo $web->keywordString; // "one, two, three"
-```
-
-::: tip Tipp
-Dies bezieht sich nur auf die Schlüsselwörter im "keyword"-Meta-Tag. Sie können auch [die Schlüsselwörter des Inhalts](/de/examples/extract-keywords.html)) mit PHPScraper extrahieren.
-:::
-
-
-## Kombinierte Meta-Tags
-
-Wenn Sie auf alle Meta-Eigenschaften zugreifen möchten, können Sie die `metaTags`-Methode verwenden. Sie gibt die oben genannten Methoden als Array zurück. Sie ist definiert als:
-
-```php
-/**
- * Liefert die gesammelten Metadaten als Array
- *
- * @return array
- */
-public function metaTags()
-{
- return [
- 'author' => $this->author(),
- 'image' => $this->image(),
- 'keywords' => $this->keywords(),
- 'description' => $this->description(),
- ];
-}
-```
-
-Im obigen Beispiel würde es wie folgt verwendet werden:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-var_dump($web->metaTags);
-/**
- * Enthält:
- *
- * [
- * 'Lorem ipsum',
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ['one', 'two', 'three'],
- * 'Lorem ipsum dolor etc.',
- * ]
- */
-```
-
-
-## Fehlende Meta-Tags
-
-Wenn Sie auf eine andere Meta-Eigenschaft zugreifen müssen, bitte lesen Sie die [Contribution Guidelines](/contributing.html) bevor Sie einen Pull Request öffnen oder ein [Issue auf GitHub](https://github.com/spekulatius/phpscraper/issues) aufmachen.
diff --git a/websites/de/examples/scrape-social-media-meta-tags.md b/websites/de/examples/scrape-social-media-meta-tags.md
deleted file mode 100644
index 72bd298..0000000
--- a/websites/de/examples/scrape-social-media-meta-tags.md
+++ /dev/null
@@ -1,103 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Social%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Social Media Meta-Tags Scrapen
-
-Das Scraping von Social Media Sharing Tags von einer Website kann mit den folgenden Methoden durchgeführt werden. Die genaue Ergebnismenge hängt von den angegebenen Tags ab. Alle Tags werden berücksichtigt, solange sie sich im vorangestellten Namensraum befinden (z.B. `twitter:` für TwitterCards).
-
-
-## Open-Graph (OG) Scrapen
-
-Das Abrufen von Open-Graph-Daten kann durchgeführt werden:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Die Seite enthält:
- *
- *
- *
- *
- *
- *
- *
- *
- *
- * @see https://test-pages.phpscraper.de/og/example.html
- */
-$web->go('https://test-pages.phpscraper.de/og/example.html');
-
-// Gibt 'Lorem Ipsum' aus:
-echo $web->openGraph['og:title'];
-
-// Gibt 'Lorem ipsum dolor etc.' aus:
-echo $web->openGraph['og:description'];
-
-// Das ganze OpenGraph-Set:
-$data = $web->openGraph;
-
-/**
- * $data enthält jetzt:
- *
- * [
- * 'og:site_name' => 'Lorem ipsum',
- * 'og:type' => 'website',
- * 'og:title' => 'Lorem Ipsum',
- * 'og:description' => 'Lorem ipsum dolor etc.',
- * 'og:url' => 'https://test-pages.phpscraper.de/meta/lorem-ipsum.html',
- * 'og:image' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- */
-```
-
-::: tip Tipp
-Wurden keine Daten gefunden, wird das Array leer zurückgegeben.
-:::
-
-
-## Twitter-Card Scrapen
-
-Das Parsen der TwitterCard funktioniert ähnlich:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Die Seite enthält die folgende Twitter-Karte:
- *
- *
- *
- *
- *
- *
- *
- *
- * @see https://test-pages.phpscraper.de/twittercard/example.html
- */
-$web->go('https://test-pages.phpscraper.de/twittercard/example.html');
-
-// Ausgegeben wird 'summary_large_image':
-echo $web->twitterCard['twitter:card'];
-
-// Ausgegeben wird 'Lorem Ipsum':
-echo $web->twitterCard['twitter:title'];
-
-// Die gesamte TwitterCard:
-$data = $web->twitterCard;
-
-/**
- * $data enthält jetzt:
- *
- * [
- * 'twitter:card' => 'summary_large_image',
- * 'twitter:title' => 'Lorem Ipsum',
- * 'twitter:description' => 'Lorem ipsum dolor etc.',
- * 'twitter:url' => 'https://test-pages.phpscraper.de/meta/lorem-ipsum.html',
- * 'twitter:image' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- */
-```
-
-Ähnlich wie bei Open Graph wird das Array leer sein, wenn keine TwitterCard Tags gefunden wurden.
diff --git a/websites/de/examples/scrape-website-title.md b/websites/de/examples/scrape-website-title.md
deleted file mode 100644
index 550c883..0000000
--- a/websites/de/examples/scrape-website-title.md
+++ /dev/null
@@ -1,89 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scrape%20Website%20Title&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Webseite-Titel Scrapen
-
-Das Scraping des Titels einer Website ist einfach. Die folgenden Beispiele zeigen, wie es mit PHPScraper funktioniert.
-
-
-## Einfaches Beispiel
-
-Ein sehr einfaches Beispiel, wie man den Titel einer Website scrapen kann:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigation zur Testseite - diese enthält den Titel-Tag "Lorem Ipsum"
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Enthält:
- *
- * Lorem Ipsum
- */
-
-// Gibt den Titel zurück. Dies sollte "Lorem Ipsum" zurückgeben.
-var_dump($web->title);
-```
-
-
-## Fehlender Titel
-
-Fehlt der Titel, wird `null` zurückgegeben:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigation zur Testseite - diese enthält keinen Titel-Tag.
-$web->go('https://test-pages.phpscraper.de/meta/missing.html');
-
-// Gibt den Titel zurück. Dies sollte null zurückgeben.
-var_dump($web->title);
-```
-
-Hinweis: Dies ist das Standardverhalten: Wenn ein Tag nicht gefunden wurde, weil er in der HTML-Quelle fehlt, wird `null` zurückgegeben. Wenn ein iterierbares Element leer ist (z.B. beim Scraping von Bildern von einer Seite ohne Bilder), wird ein leeres Array zurückgegeben.
-
-
-## Besondere Zeichen
-
-Laden eines Website-Titels mit deutschen Umlauten
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Diese enthält:
- *
- * A page with plenty of German umlaute everywhere (ä ü ö)
- */
-$web->go('https://test-pages.phpscraper.de/meta/german-umlaute.html');
-
-// Ausgabe des Titels: "A page with plenty of German umlaute everywhere (ä ü ö)"
-echo $web->title;
-```
-
-Es sollte in ähnlicher Weise mit allen UTF-8-Zeichen funktionieren.
-
-
-## HTML-Elemente
-
-HTML-Entities sollten aufgelöst werden
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigation zur Testseite. Enthält:
- *
- * Cat & Mouse
- */
-$web->go('https://test-pages.phpscraper.de/meta/html-entities.html');
-
-// Ausgabe des Titels: "Cat & Mouse"
-echo $web->title;
-```
-
-::: tip Tipp
-Entities und Sonderzeichen wurden in der gesamten Bibliothek berücksichtigt. Wenn Sie eine Stelle finden, an der diese nicht wie erwartet funktionieren, melden Sie dies bitte unter [issue](https://github.com/spekulatius/PHPScraper/issues).
-:::
diff --git a/websites/de/misc/show-case.md b/websites/de/misc/show-case.md
deleted file mode 100644
index 24372bc..0000000
--- a/websites/de/misc/show-case.md
+++ /dev/null
@@ -1,7 +0,0 @@
-# Show Case
-
-Zusätzlich zu den [Tutorials](/de/misc/tutorials.html) verwenden diese Bibliotheken und Composer-Pakete ebenfalls PHPScraper. Sie können sich den Code ansehen, um mehr über die einzelnen Anwendungsfälle zu erfahren.
-
-- [datlechin/flarum-link-preview](https://github.com/datlechin/flarum-link-preview): Link preview for Flarum Boards.
-
-If you'd like add your project please submit a PR.
\ No newline at end of file
diff --git a/websites/de/misc/sponsors.md b/websites/de/misc/sponsors.md
deleted file mode 100644
index 1137ce3..0000000
--- a/websites/de/misc/sponsors.md
+++ /dev/null
@@ -1,13 +0,0 @@
-# Sponsoren
-
-PHP Scraper wird unterstützt von:
-
-
-
-## Sponsor werden
-
-Vielen Dank für Ihr Interesse, PHP Scraper zu unterstützen! PHP Scraper bietet Ihnen auf Ihre Bedürfnisse zugeschnittene Sponsoring-Pakete an. Bitte [melden Sie sich](https://peterthaleikis.com/contact), um Details zu besprechen.
-
-## Kommerzielle Unterstützung
-
-Unterstützung für kommerzielle Anwendungen, kommerzielle Lizenzen, kundenspezifische Entwicklung und ähnliches kann [besprochen](https://peterthaleikis.com/contact) werden. Wir freuen uns, Ihr Projekt zu unterstützen.
diff --git a/websites/de/misc/support.md b/websites/de/misc/support.md
deleted file mode 100644
index 2932fc2..0000000
--- a/websites/de/misc/support.md
+++ /dev/null
@@ -1,13 +0,0 @@
-# Unterstützung
-
-## Weitere Beispiele
-
-Wenn Sie weitere Beispiele benötigen, sehen Sie sich die [tests](https://github.com/spekulatius/phpscraper/tree/master/tests) an. Diese enthalten weitere Beispiele für das Auslesen von Daten aus Websites.
-
-## Fehler und andere Probleme
-
-Sollten Sie Fehler oder Probleme ähnlicher Art bemerken, melden Sie bitte ein [Thema auf GitHub](https://github.com/spekulatius/PHPScraper/issues). Vergessen Sie nicht, die detaillierten Informationen anzugeben, um das Problem zu replizieren.
-
-## Kommerzieller Support
-
-Unterstützung für kommerzielle Anwendungen, kommerzielle Lizenzen, benutzerdefinierte Entwicklung usw. kann [besprochen](https://peterthaleikis.com/contact) werden.
diff --git a/websites/de/misc/tutorials.md b/websites/de/misc/tutorials.md
deleted file mode 100644
index 7f7bbad..0000000
--- a/websites/de/misc/tutorials.md
+++ /dev/null
@@ -1,7 +0,0 @@
-# PHP Scraping Tutorials
-
-Die folgenden Tutorials verwenden PHPScraper und könnten hilfreich sein, mehr über die verschiedenen Möglichkeiten der Nutzung von PHPScraper zu lernen.
-
-- ...
-
-Bitte beachten Sie, dass die Tutorials nicht überprüft wurden und veraltet sein könnten.
\ No newline at end of file
diff --git a/websites/es/README.md b/websites/es/README.md
deleted file mode 100644
index a530709..0000000
--- a/websites/es/README.md
+++ /dev/null
@@ -1,169 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP%20Scraper:%20Devolviendo%20la%20simplicidad%20al%20scraping%20y%20al%20crawling&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-PHP Scraper: Devolviendo la simplicidad al scraping y al crawling
-=================================================================
-
-![PHP Scraper: Devolviendo la simplicidad al scraping y al crawling](logo-light.png)
-
-*de [Peter Thaleikis](https://peterthaleikis.com)*
-
-El raspado de la web usando PHP puede hacerse más fácilmente. Esta es una envoltura de opinión alrededor de algunas grandes bibliotecas de PHP para hacer el acceso a la web más fácil.
-
-Los ejemplos cuentan la historia mucho mejor. Echa un vistazo.
-
-::: tip Nota
-Este sitio web de documentación en español es WIP. Por favor, eleve un PR en GitHub si encuentra algún error. Gracias!
-:::
-
-
-La idea 💡️
-----------
-
-Acceder a sitios web y recoger información básica de la web es demasiado complejo. Esta envoltura alrededor de [Goutte](https://github.com/FriendsOfPHP/Goutte) lo hace más fácil. Te ahorra el uso de XPath y demás, dándote acceso directo a todo lo que necesitas. Web scraping con PHP reimaginado.
-
-
-Apoyos 💪️
--------------
-
-Este proyecto está patrocinado por:
-
-
-
-¿Quieres patrocinar este proyecto? [Escríbeme](https://peterthaleikis.com/contact).
-
-
-Ejemplos
---------
-
-Aquí hay algunos ejemplos de lo que la biblioteca de raspado web puede hacer en este momento:
-
-### Scrape Meta Information:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de pruebas. Contiene:
- *
- *
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Obtener la información:
-echo $web->author; // "Lorem ipsum"
-echo $web->description; // "Lorem ipsum dolor etc."
-echo $web->image; // "https://test-pages.phpscraper.de/assets/cat.jpg"
-```
-
-La mayor parte de la información se puede acceder directamente, ya sea como cadena o como matriz.
-
-
-### Raspado de contenidos, como imágenes:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de prueba. Esta página contiene dos imágenes:
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-var_dump($web->imagesWithDetails);
-/**
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'absolute path',
- * 'width' => null,
- * 'height' => null,
- * ],
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'relative path',
- * 'width' => null,
- * 'height' => null,
- * ]
- */
-```
-
-Alguna información *opcionalmente* se devuelve como un array con detalles. Para este ejemplo, una simple lista de imágenes está disponible usando `$web->images` también. Esto debería facilitar el raspado de la web.
-
-Se puede encontrar más código de ejemplo en los ejemplos y pruebas.
-
-
-Instalación
-------------
-
-La instalación suele realizarse mediante [Composer](https://getcomposer.org).
-
-### Instalación con Composer
-
-```bash
-composer require spekulatius/phpscraper
-```
-
-Una vez completada la instalación, el paquete será recogido por el autocargador de Composer. En las aplicaciones y frameworks típicos de PHP como Laravel o Symfony ya puedes empezar a hacer scraping. Ahora puedes usar cualquiera de los ejemplos anotados o los ejemplos en la carpeta `tests/`.
-
-### Uso en proyectos VanillaPHP
-
-Si estás construyendo un proyecto VanillaPHP, necesitarás incluir el autoloader en tu script en la parte superior de tu script PHP:
-
-```php
-require 'vendor/autoload.php';
-```
-
-Si estás usando un framework como Laravel, Symfony, Laminas, Phalcon o CakePHP, no necesitarás este paso. El autoloader se incluye automáticamente.
-
-
-Configuración
--------------
-
-La configuración adicional es opcional. A continuación se muestran las opciones correctamente disponibles.
-
-### Soporte de Proxy
-
-Si necesita proxies, puede configurar el soporte de proxy con `setConfig`:
-
-```php
-$web->setConfig(['proxy' => 'http://user:password@127.0.0.1:3128']);
-```
-
-### Timeout
-
-Puedes establecer el `timeout` usando `setConfig`:
-
-```php
-$web->setConfig(['timeout' => 15]);
-```
-
-Si se pone el tiempo de espera a cero, se desactivará.
-
-### Desactivación de SSL
-
-Aunque no se recomienda, puede ser necesario desactivar las comprobaciones de SSL. Puede hacerlo utilizando:
-
-```php
-$web->setConfig(['disable_ssl' => true]);
-```
-
-Puedes llamar a `setConfig` varias veces. Almacena la configuración y la fusiona con los ajustes anteriores. Esto debe tenerse en cuenta en el improbable caso de uso cuando se desestablecen los valores.
-
-
-¿Has encontrado un error y lo has arreglado? ¡Impresionante!
-----------------------------------
-Antes de empezar, familiarícese con las [directrices de contribución](/contributing.html). Si tiene alguna pregunta, no dude en ponerse en contacto con nosotros.
-
-
-Pruebas: Asegurarse de que funciona.
-----------------------------
-
-El código está cubierto a grandes rasgos con pruebas de extremo a extremo. Para ello, se alojan páginas web sencillas en *https://test-pages.phpscraper.de/*, cargado y analizado usando [PHPUnit](https://phpunit.de/). Estas pruebas también son adecuadas como ejemplos - véase `tests/`!
-
-Dicho esto, es probable que haya casos límite que no funcionen y puedan causar problemas. Si encuentras uno, por favor, levanta un bug en GitHub.
diff --git a/websites/es/apis/alibaba.md b/websites/es/apis/alibaba.md
deleted file mode 100644
index aa29e44..0000000
--- a/websites/es/apis/alibaba.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# Alibaba/AliExpress Scraper API
-
-El equipo detrás de PHP Scraper está trabajando en la provisión de APIs comerciales para varios casos de uso común así como para plataformas. Estas APIs no son auto-alojadas. No tendrá que preocuparse de rotar IPs/proxies, ejecutando un navegador sin cabeza como Puppeteer. Una simple llamada a la API le permitirá obtener toda la información necesaria. Los servicios serán proporcionados en una atractiva estructura de tarifas dependiente del uso.
-
-Para Alibaba estamos considerando la implementación de una API con el siguiente alcance.
-
-## Puntos finales propuestos
-
-- Búsqueda de productos por palabra clave
-- Obtener información sobre el producto
-
-::: tip CONSEJO
-Tenga en cuenta que esta lista de puntos finales de la API no es *final* y es probable que cambie.
-:::
-
-## Soporte de la plataforma
-
-Con el enfoque de utilizar una API gestionada, los usuarios se liberan de preocuparse por la rotación de proxies, los problemas de escalado y las interrupciones. Además, se admite una amplia gama de plataformas. Se puede integrar fácilmente en NodeJS, Python (sin peticiones ni beautifulsoap), Golang, etc. Cualquier plataforma que permita ejecutar peticiones GET puede ser programada para solicitar datos de este servicio.
diff --git a/websites/es/apis/amazon.md b/websites/es/apis/amazon.md
deleted file mode 100644
index 20e270b..0000000
--- a/websites/es/apis/amazon.md
+++ /dev/null
@@ -1,22 +0,0 @@
-# Amazon Scraper API
-
-El equipo detrás de PHP Scraper está trabajando en la provisión de APIs comerciales para varios casos de uso común así como para plataformas. Estas APIs no son auto-alojadas. No tendrá que preocuparse de rotar IPs/proxies, ejecutando un navegador sin cabeza como Puppeteer. Una simple llamada a la API le permitirá obtener toda la información necesaria. Los servicios serán proporcionados en una atractiva estructura de tarifas dependiente del uso.
-
-Para Amazon estamos considerando la implementación de una API con el siguiente alcance.
-
-## Puntos finales propuestos
-
-- Obtener información del producto
-- Obtener recomendaciones
-- Obtener información de la revisión
-- Obtener información del vendedor
-- Obtener todos los precios de los vendedores
-- Buscar productos por palabra clave o ID de vendedor
-
-::: tip CONSEJO
-Tenga en cuenta que esta lista de puntos finales de la API no es *final* y es probable que cambie.
-:::
-
-## Soporte de plataforma
-
-Con el enfoque de utilizar una API gestionada, los usuarios se liberan de preocuparse por la rotación de proxies, los problemas de escalado y las interrupciones. Además, se admite una amplia gama de plataformas. Se puede integrar fácilmente en NodeJS, Python (sin peticiones ni beautifulsoap), Golang, etc. Cualquier plataforma que permita ejecutar peticiones GET puede ser programada para solicitar datos de este servicio.
diff --git a/websites/es/apis/etsy.md b/websites/es/apis/etsy.md
deleted file mode 100644
index 30ce38a..0000000
--- a/websites/es/apis/etsy.md
+++ /dev/null
@@ -1,22 +0,0 @@
-# Etsy Scraper API
-
-El equipo detrás de PHP Scraper está trabajando en la provisión de APIs comerciales para varios casos de uso común así como para plataformas. Estas APIs no son auto-alojadas. No tendrá que preocuparse de rotar IPs/proxies, ejecutando un navegador sin cabeza como Puppeteer. Una simple llamada a la API le permitirá obtener toda la información necesaria. Los servicios serán proporcionados en una atractiva estructura de tarifas dependiente del uso.
-
-Para Etsy estamos considerando la implementación de una API con el siguiente alcance.
-
-## Puntos finales propuestos
-
-- Obtener información del producto
-- Obtener recomendaciones
-- Obtener información de la revisión
-- Obtener información del vendedor
-- Obtener todos los precios de los vendedores
-- Buscar productos por palabra clave o ID de vendedor
-
-::: tip CONSEJO
-Tenga en cuenta que esta lista de puntos finales de la API no es *final* y es probable que cambie.
-:::
-
-## Soporte de plataforma
-
-Con el enfoque de utilizar una API gestionada, los usuarios se liberan de preocuparse por la rotación de proxies, los problemas de escalado y las interrupciones. Además, se admite una amplia gama de plataformas. Se puede integrar fácilmente en NodeJS, Python (sin peticiones ni beautifulsoap), Golang, etc. Cualquier plataforma que permita ejecutar peticiones GET puede ser programada para solicitar datos de este servicio.
diff --git a/websites/es/apis/facebook.md b/websites/es/apis/facebook.md
deleted file mode 100644
index 99c86ec..0000000
--- a/websites/es/apis/facebook.md
+++ /dev/null
@@ -1,28 +0,0 @@
-# Facebook Scraper API
-
-El equipo detrás de PHP Scraper está trabajando en proveer APIs comerciales para varios casos de uso común así como plataformas. Estas APIs no son auto-alojadas. No tendrás que preocuparte por rotar IPs/proxies, ejecutando un navegador sin cabeza como Puppeteer. Una simple llamada a la API le permitirá obtener toda la información necesaria. Los servicios serán proporcionados en una atractiva estructura de tarifas dependiente del uso.
-
-Para Facebook estamos considerando la implementación de una API con el siguiente alcance.
-
-## Puntos finales propuestos
-
-- Usuario: Perfil de usuario público
-- Usuario: Otras cuentas sociales
-- Usuario: Lista de amigos
-- Usuario: Imágenes
-- Usuario: Mensajes de ubicación
-- Usuario: Mensajes de usuario
-- Público Grupos y grupos privados con clave: Perfil del grupo público
-- Público Grupos y grupos privados con clave: Lista de miembros
-- Público Grupos y grupos privados con clave: Imágenes
-- Público Grupos y grupos privados con clave: Perfil del grupo público Mensajes de ubicación
-- Público Grupos y grupos privados con clave: Mensajes Mensajes
-- Mensajes: Detalles del post público (incluyendo comentarios, likes, likers, etc.)
-
-::: tip CONSEJO
-Tenga en cuenta que esta lista de puntos finales de la API no es *final* y es probable que cambie.
-:::
-
-## Soporte de la plataforma
-
-Con el enfoque de utilizar una API gestionada, los usuarios se liberan de preocuparse por la rotación de proxies, los problemas de escalado y las interrupciones. Además, se admite una amplia gama de plataformas. Se puede integrar fácilmente en NodeJS, Python (sin peticiones ni beautifulsoap), Golang, etc. Cualquier plataforma que permita ejecutar peticiones GET puede ser programada para solicitar datos de este servicio.
diff --git a/websites/es/apis/instagram.md b/websites/es/apis/instagram.md
deleted file mode 100644
index 489cffb..0000000
--- a/websites/es/apis/instagram.md
+++ /dev/null
@@ -1,34 +0,0 @@
-# Instagram Scraper API
-
-El equipo detrás de PHP Scraper está trabajando en proporcionar APIs comerciales para varios casos de uso común, así como plataformas. Estas APIs no son auto-alojadas. No tendrás que preocuparte de rotar IPs/proxies, ejecutando un navegador headless como Puppeteer. Una simple llamada a la API le permitirá obtener toda la información necesaria. Los servicios serán proporcionados en una atractiva estructura de tarifas dependiente del uso.
-
-Para Instagram estamos considerando la implementación de una API con el siguiente alcance.
-
-## Puntos finales propuestos
-
-- Usuario: Detalles del perfil
-- Usuario: Destacados
-- Usuario: Mensajes
-- Usuario: Mensajes etiquetados
-- Usuario: Mensajes públicos
-- Usuario: Seguidores
-- Usuario: Obtener historias
-- Usuario: Estado actual
-- Usuario: Otras cuentas sociales
-- Mensajes Públicos: Comentarios
-- Publicación pública: Likers
-- Descargador de historias con conversión a mp4, mp3, etc.
-- Mensajes con Hashtags
-- Mensajes de ubicación
-- Búsqueda por ubicación
-- Detalles del puesto
-- Perfiles relacionados
-- Buscar
-
-::: tip CONSEJO
-Tenga en cuenta que esta lista de puntos finales de la API no es *final* y es probable que cambie.
-:::
-
-## Soporte de la plataforma
-
-Con el enfoque de utilizar una API gestionada, los usuarios se liberan de preocuparse por la rotación de proxies, los problemas de escalado y las interrupciones. Además, se admite una amplia gama de plataformas. Se puede integrar fácilmente en NodeJS, Python (sin peticiones ni beautifulsoap), Golang, etc. Cualquier plataforma que permita ejecutar peticiones GET puede ser programada para solicitar datos de este servicio.
diff --git a/websites/es/apis/linkedin.md b/websites/es/apis/linkedin.md
deleted file mode 100644
index 4715801..0000000
--- a/websites/es/apis/linkedin.md
+++ /dev/null
@@ -1,21 +0,0 @@
-# LinkedIn Scraper API
-
-El equipo detrás de PHP Scraper está trabajando en proveer APIs comerciales para varios casos de uso común así como plataformas. Estas APIs no son auto-alojadas. No tendrás que preocuparte de rotar IPs/proxies, ejecutando un navegador headless como Puppeteer. Una simple llamada a la API le permitirá obtener toda la información necesaria. Los servicios serán proporcionados en una atractiva estructura de tarifas dependiente del uso.
-
-Para LinkedIn estamos considerando la implementación de una API con el siguiente alcance.
-
-## Puntos finales propuestos
-
-- Usuario: Detalles del perfil
-- Usuario: Mensajes
-- Puestos: Descargador y convertidor de vídeo.
-- Empresa: Detalles del perfil
-- Búsqueda de empleo
-
-::: tip CONSEJO
-Tenga en cuenta que esta lista de puntos finales de la API no es *final* y es probable que cambie.
-:::
-
-## Soporte de la plataforma
-
-Con el enfoque de utilizar una API gestionada, los usuarios se liberan de preocuparse por la rotación de proxies, los problemas de escalado y las interrupciones. Además, se admite una amplia gama de plataformas. Se puede integrar fácilmente en NodeJS, Python (sin peticiones ni beautifulsoap), Golang, etc. Cualquier plataforma que permita ejecutar peticiones GET puede ser programada para solicitar datos de este servicio.
diff --git a/websites/es/apis/target.md b/websites/es/apis/target.md
deleted file mode 100644
index c0da65e..0000000
--- a/websites/es/apis/target.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# Target Scraper API
-
-El equipo detrás de PHP Scraper está trabajando en proveer APIs comerciales para varios casos de uso común así como plataformas. Estas APIs no son auto-alojadas. No tendrá que preocuparse de rotar IPs/proxies, ejecutando un navegador sin cabeza como Puppeteer. Una simple llamada a la API le permitirá obtener toda la información necesaria. Los servicios serán proporcionados en una atractiva estructura de tarifas dependiente del uso.
-
-Para Target estamos considerando la implementación de una API con el siguiente alcance.
-
-## Puntos finales propuestos
-
-- Obtener detalles del producto
-- Búsqueda de productos por palabra clave
-
-::: tip CONSEJO
-Tenga en cuenta que esta lista de puntos finales de la API no es *final* y es probable que cambie.
-:::
-
-## Soporte de la plataforma
-
-Con el enfoque de utilizar una API gestionada, los usuarios se liberan de preocuparse por la rotación de proxies, los problemas de escalado y las interrupciones. Además, se admite una amplia gama de plataformas. Se puede integrar fácilmente en NodeJS, Python (sin peticiones ni beautifulsoap), Golang, etc. Cualquier plataforma que permita ejecutar peticiones GET puede ser programada para solicitar datos de este servicio.
diff --git a/websites/es/apis/tiktok.md b/websites/es/apis/tiktok.md
deleted file mode 100644
index bd71897..0000000
--- a/websites/es/apis/tiktok.md
+++ /dev/null
@@ -1,21 +0,0 @@
-# TikTok Scraper API
-
-El equipo detrás de PHP Scraper está trabajando en la provisión de APIs comerciales para varios casos de uso común así como para plataformas. Estas APIs no son auto-alojadas. No tendrá que preocuparse de rotar IPs/proxies, ejecutando un navegador sin cabeza como Puppeteer. Una simple llamada a la API le permitirá obtener toda la información necesaria. Los servicios serán proporcionados en una atractiva estructura de tarifas dependiente del uso.
-
-Para TikTok estamos considerando la implementación de una API con el siguiente alcance.
-
-## Puntos finales soportados propuestos
-
-- Búsqueda por etiqueta
-- Usuario: Detalles del perfil público
-- Usuario: Otras cuentas sociales
-- Detalles del vídeo
-- Descarga de vídeo con conversión a mp4, mp3, etc. y sin marca de agua
-
-::: tip CONSEJO
-Tenga en cuenta que esta lista de puntos finales de la API no es *final* y es probable que cambie.
-:::
-
-## Soporte de la plataforma
-
-Con el enfoque de utilizar una API gestionada, los usuarios se liberan de preocuparse por la rotación de proxies, los problemas de escalado y las interrupciones. Además, se admite una amplia gama de plataformas. Se puede integrar fácilmente en NodeJS, Python (sin peticiones ni beautifulsoap), Golang, etc. Cualquier plataforma que permita ejecutar peticiones GET puede ser programada para solicitar datos de este servicio.
diff --git a/websites/es/apis/walmart.md b/websites/es/apis/walmart.md
deleted file mode 100644
index 604587a..0000000
--- a/websites/es/apis/walmart.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# Walmart Scraper API
-
-El equipo detrás de PHP Scraper está trabajando en proveer APIs comerciales para varios casos de uso común así como plataformas. Estas APIs no son auto-alojadas. No tendrá que preocuparse de rotar IPs/proxies, ejecutando un navegador sin cabeza como Puppeteer. Una simple llamada a la API le permitirá obtener toda la información necesaria. Los servicios serán proporcionados en una atractiva estructura de tarifas dependiente del uso.
-
-Para Walmart estamos considerando la implementación de una API con el siguiente alcance.
-
-## Puntos finales propuestos
-
-- Obtener detalles del producto
-- Búsqueda de productos por palabra clave
-
-::: tip CONSEJO
-Tenga en cuenta que esta lista de puntos finales de la API no es *final* y es probable que cambie.
-:::
-
-## Soporte de la plataforma
-
-Con el enfoque de utilizar una API gestionada, los usuarios se liberan de preocuparse por la rotación de proxies, los problemas de escalado y las interrupciones. Además, se admite una amplia gama de plataformas. Se puede integrar fácilmente en NodeJS, Python (sin peticiones ni beautifulsoap), Golang, etc. Cualquier plataforma que permita ejecutar peticiones GET puede ser programada para solicitar datos de este servicio.
diff --git a/websites/es/apis/zalando.md b/websites/es/apis/zalando.md
deleted file mode 100644
index 68a93d4..0000000
--- a/websites/es/apis/zalando.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# Zalando Scraper API
-
-El equipo detrás de PHP Scraper está trabajando en proporcionar APIs comerciales para varios casos de uso común, así como plataformas. Estas APIs no son auto-alojadas. No tendrá que preocuparse de rotar IPs/proxies, ejecutando un navegador sin cabeza como Puppeteer. Una simple llamada a la API le permitirá obtener toda la información necesaria. Los servicios serán proporcionados en una atractiva estructura de tarifas dependiente del uso.
-
-Para Zalando estamos considerando la implementación de una API con el siguiente alcance.
-
-## Puntos finales propuestos
-
-- Obtener detalles del producto
-- Búsqueda de productos por palabra clave
-
-::: tip CONSEJO
-Tenga en cuenta que esta lista de puntos finales de la API no es *final* y es probable que cambie.
-:::
-
-## Soporte de la plataforma
-
-Con el enfoque de utilizar una API gestionada, los usuarios se liberan de preocuparse por la rotación de proxies, los problemas de escalado y las interrupciones. Además, se admite una amplia gama de plataformas. Se puede integrar fácilmente en NodeJS, Python (sin peticiones ni beautifulsoap), Golang, etc. Cualquier plataforma que permita ejecutar peticiones GET puede ser programada para solicitar datos de este servicio.
diff --git a/websites/es/examples/extract-keywords.md b/websites/es/examples/extract-keywords.md
deleted file mode 100644
index a893f39..0000000
--- a/websites/es/examples/extract-keywords.md
+++ /dev/null
@@ -1,123 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Extract%20Keywords&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Extraer palabras clave
-
-Mientras que raspar el contenido es a menudo suficiente, a veces se requiere extraer términos y frases significativas (palabras clave) de este contenido. PHPScraper le permite extraer las palabras clave del sitio web directamente. Para ello utiliza:
-
-- el título del sitio web,
-- los meta tags,
-- todos los encabezados,
-- los párrafos de la página,
-- los anclajes y los títulos de los enlaces, así como
-- los atributos del título de las imágenes
-
-Aunque se extraigan estas frases de palabras clave, no significa que la página se clasifique realmente para estas palabras clave. La decisión final sobre qué palabras clave clasifica una página web corresponde al motor de búsqueda.
-
-El siguiente ejemplo devolverá una lista de todas las palabras clave extraídas de la página web:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navega a la página de prueba.
-// Contiene 3 párrafos del artículo de Wikipedia en inglés para "lorem ipsum"
-$web->go('https://test-pages.phpscraper.de/content/keywords.html');
-
-// Comprobar el número de palabras clave.
-$keywords = $web->contentKeywords;
-echo "Esta página contiene al menos " . count($keywords) . " palabras clave/frases.\n\n";
-
-// Recorrer en bucle las palabras clave
-foreach ($keywords as $keyword) {
- echo " - " . $keyword . "\n";
-}
-
-/**
- * Se imprimirá:
- *
- * Esta página contiene al menos 40 palabras clave/frases.
- *
- * [...]
- * - graphic
- * - improper latin
- * - introduced
- * - keyword extraction tests
- * - letraset transfer sheets
- * - lorem ipsum
- * - lorem ipsum php rake library lorem ipsum
- * - lorem ipsum text
- * - make
- * - malorum
- * - microsoft word
- * - mid-1980s
- * - nonsensical
- * - page
- * - paragraphs
- * - philosopher cicero
- * - php rake library
- * - popular word processors including pages
- * - popularized
- * - removed
- * - roman statesman
- * - source
- * [...]
- */
-```
-
-::: tip CONSEJO
-El idioma por defecto (locale) es `en_US`. Se pueden pasar otros idiomas como parámetro. Actualmente sólo funciona para una selección de idiomas. Consulte esta [lista](https://github.com/Donatello-za/rake-php-plus#currently-supported-languages) para obtener más información.
-:::
-
-
-## Puntuación de las palabras clave
-
-No todas las palabras clave tienen el mismo peso en los algoritmos de clasificación de los motores de búsqueda. Una mezcla de varios factores y señales de SEO decide el peso que un motor de búsqueda asigna a una palabra. La frecuencia de las palabras, la longitud de los textos y las variaciones, como los sinónimos, pueden dar lugar a una ponderación diferente.
-
-PHPScraper le permite obtener una indicación del peso de las palabras clave en forma de puntuación:
-
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navega a la página de prueba.
-// Contiene 3 párrafos del artículo de Wikipedia en inglés para "lorem ipsum"
-$web->go('https://test-pages.phpscraper.de/content/keywords.html');
-
-// Comprobar el número de palabras clave.
-$keywords = $web->contentKeywordsWithScores;
-echo "Esta página contiene al menos " . count($keywords) . " palabras clave/frases.\n\n";
-
-// Recorrer en bucle las palabras clave
-foreach ($keywords as $keyword => $score) {
- echo sprintf(" - %s (%s)\n", $keyword, $score);
-}
-
-/**
- * Se imprimirá:
- *
- * Esta página contiene al menos 40 palabras clave/frases.
- *
- * [...]
- * - 1960s (1.0)
- * - added (1.0)
- * - adopted lorem ipsum (11.0)
- * - advertisements (1.0)
- * - aldus employed (4.0)
- * - corrupted version (4.0)
- * - graphic (1.0)
- * - improper latin (4.0)
- * - introduced (1.0)
- * - keyword extraction tests (9.0)
- * - test (1.0)
- * - microsoft word (5.3333333333333)
- * - english wikipedia (4.0)
- * - lorem ipsum (8.0)
- * - lorem ipsum text (11.0)
- * [...]
- */
-```
-
-::: tip CONSEJO
-Las funciones PHP [similar_text](https://www.php.net/manual/en/function.similar-text.php) y [levenshtein](https://www.php.net/manual/en/function.levenshtein.php) pueden ayudarle a identificar y fusionar palabras clave similares, así como variaciones tipográficas de palabras clave. [Keyword Merge](https://github.com/spekulatius/keyword-merge) es un paquete de compositor que ayuda a clasificar palabras clave similares.
-:::
diff --git a/websites/es/examples/headings.md b/websites/es/examples/headings.md
deleted file mode 100644
index 8e9c0af..0000000
--- a/websites/es/examples/headings.md
+++ /dev/null
@@ -1,124 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Headings&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Recolección de encabezados
-
-Los encabezados pueden ser útiles para hacerse una idea del contenido de un sitio web. El siguiente ejemplo muestra cómo hacer scraping:
-
- - Un solo encabezado
- - Todos los encabezamientos de un nivel determinado (por ejemplo, `
`)
- - Todos los encabezamientos de una página
-
-
-## Raspado de un solo encabezado
-
-Raspar un solo encabezado es fácil y se puede hacer siguiendo este ejemplo:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de pruebas. Contiene:
- *
- * Outline Test
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-// Imprimir la cabecera H1
-echo $web->h1[0]; // "Outline Test"
-```
-
-::: tip CONSEJO
-El [título del sitio web](/es/examples/scrape-website-title.html) y el encabezado 1 (`
`) pueden ser diferentes. Asegúrese de recuperar el correcto.
-:::
-
-
-## Rúbricas por nivel
-
-Puede haber casos en los que desee recuperar todos los títulos de un nivel determinado. El siguiente ejemplo muestra cómo hacerlo:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de pruebas. Contiene:
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-/**
- * Obtenga los encabezados h3:
- *
- * [
- * 'Example 1',
- * 'Example 2',
- * 'Example 3'
- * ]
- */
-$web->h3;
-```
-
-Si no se encuentra ningún encabezamiento, la matriz se deja vacía.
-
-
-## Todos los encabezados de una página
-
-Para acceder a todos los encabezados de una página, puede hacerlo accediendo a los diferentes niveles del 1 al 6. O, alternativamente, puede acceder a todos a la vez:
-
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de la prueba. Esta página contiene:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-/**
- * $headings contiene ahora:
- *
- * [
- * [
- * 'We are testing here!'
- * ],
- * [
- * 'Examples'
- * ],
- * [
- * 'Example 1',
- * 'Example 2',
- * 'Example 3',
- * ],
- * [],
- * [],
- * []
- * ]
- */
-$web->headings;
-```
-
-Como puede ver, esto no contiene ninguna información sobre la estructura de los encabezados. Es puramente para saber qué encabezados existen. Si quiere tener un [esquema](/es/examples/outline.html) tendrá que utilizar los métodos relacionados.
diff --git a/websites/es/examples/lists.md b/websites/es/examples/lists.md
deleted file mode 100644
index de41767..0000000
--- a/websites/es/examples/lists.md
+++ /dev/null
@@ -1,70 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Lists&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Listas de raspado
-
-El raspado de listas sigue un enfoque similar al de otros raspados con PHPScraper:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegar a la página de prueba. Esta página contiene:
- *
- *
)
- *
- * [
- * "type" => "ul",
- * "children" => ... // Lista de childNodes
- * "children_plain" =>
- * [
- * "Unordered list item 1"
- * "Unordered list item 2"
- * "Unordered list item with HTML"
- * ]
- * ]
- */
-var_dump($web->unorderedLists);
-
-
-/**
- * Sólo listas ordenadas ()
- *
- * [
- * "type" => "ul",
- * "children" => ... // Lista de childNodes
- * "children_plain" =>
- * [
- * "Ordered list item 1"
- * "Ordered list item 2"
- * "Ordered list item with HTML"
- * ]
- * ]
- */
-var_dump($web->orderedLists);
-
-// Ambas listas combinadas (como la anterior)
-var_dump($web->lists);
-```
-
-::: warning Listas anidadas
-Por el momento, esto no maneja bien las listas anidadas. Las listas anidadas se incluyen en el resultado como `hijos` para permitir su procesamiento posterior.
-:::
diff --git a/websites/es/examples/navigation.md b/websites/es/examples/navigation.md
deleted file mode 100644
index 279414c..0000000
--- a/websites/es/examples/navigation.md
+++ /dev/null
@@ -1,59 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Navigate%20while%20Scraping&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Navegación
-
-Aunque PHPScraper está pensado principalmente para analizar sitios web y recopilar información, también se puede utilizar para navegar por sitios web. A continuación hay ejemplos de formas de *navegar* por un sitio web.
-
-
-## Navegación usando URLs
-
-Puedes navegar a cualquier URL. Estas URLs suelen proceder de los [enlaces analizados](/es/examples/scrape-links.html).
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Comenzamos en la página de prueba #1.
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-// Imprime el título para ver si estamos en la página correcta...
-echo $web->h1[0]; // 'Page #1'
-
-
-// Navegamos a la página de prueba #2 usando la URL absoluta.
-$web->clickLink('https://test-pages.phpscraper.de/navigation/2.html');
-
-// Imprime el título para ver si estamos en la página correcta...
-echo $web->h1[0]; // 'Page #2'
-```
-
-
-## Navegación con textos de anclaje
-
-En un sitio web se puede *hacer clic* en los enlaces utilizando sus textos de anclaje:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Comenzamos en la página de prueba #1.
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-/**
- * Esta página contiene:
- *
- * 2 relative
- */
-
-// Imprime el título para ver si estamos en la página correcta...
-echo $web->h1[0]; // 'Page #1'
-
-
-// Navegamos a la página de prueba #2 usando el texto que tiene en la página.
-$web->clickLink('2 relativo');
-
-// Imprime el título para ver si estamos en la página correcta...
-echo $web->h1[0]; // 'Page #2'
-```
-
-Esta funcionalidad básica debería permitirle navegar por los sitios web.
diff --git a/websites/es/examples/outline.md b/websites/es/examples/outline.md
deleted file mode 100644
index 2d1b4cd..0000000
--- a/websites/es/examples/outline.md
+++ /dev/null
@@ -1,215 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scrape%20Content%20Outline&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Extracción de contornos
-
-Si bien es posible que quiera acceder sólo a los [`encabezados`](/es/examples/headings.html) para procesar, por ejemplo, el número o la longitud de los epígrafes, no siempre es suficiente. En algunos casos puede ser necesario identificar la estructura real del contenido. Para estos casos de uso, puede considerar uno de estos métodos:
-
- - `outline` funciona de forma similar al método `headings` mencionado anteriormente. También devuelve todos los encabezados, pero mantiene la estructura del documento original en su lugar y proporciona los niveles de encabezado (por ejemplo, `h1`) solo con la salida.
-
- - El método `outlineWithParagraphs` funciona de forma similar a `outline`, con la diferencia de que esta llamada también incluye los párrafos.
-
- - `CleanOutlineWithParagraphs` funciona de forma similar a `outlineWithParagraphs`, con la diferencia de que se eliminan las etiquetas HTML vacías.
-
-Los siguientes ejemplos deberían ayudar a entender mejor la funcionalidad. Hay métodos dedicados para la [extracción de palabras clave](/es/examples/extract-keywords.html) disponibles.
-
-
-## Extraer el esquema
-
-El esquema del contenido permite construir un índice del documento. El siguiente ejemplo construye una versión markdown de los encabezados del documento solicitado:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de la prueba. Esta página contiene:
- *
- *
We are testing here!
- * [...]
- *
- *
Examples
- * [...]
- *
- *
Example 1
- * [...]
- *
- *
Example 2
- * [...]
- *
- *
Example 3
- * [...]
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-/**
- * $outline se establecerá para que contenga:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ]
- * ]
- */
-$outline = $web->outline;
-```
-
-
-## Extraer el esquema con párrafos
-
-El siguiente método funciona de manera similar a `outline`, pero también incluye los párrafos como parte del array devuelto:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de la prueba. Esta página contiene:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-
-$content = $web->outlineWithParagraphs;
-/**
- * $content ahora contiene:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "p",
- * "content" => "This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example."
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "p",
- * "content" => "There are numerous examples on the website. Please check them out to get more context on how scraping works."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be an example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be the second example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be another example."
- * ], [
- * "tag" => "p",
- * "content" => ""
- * ]
- * ]
- */
-```
-
-
-## Extraer el esquema depurado con los párrafos
-
-El siguiente método funciona de manera similar a `outlineWithParagraphs`, pero no incluye ningún encabezado o párrafo vacío como parte del array devuelto:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de la prueba. Esta página contiene:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-
-$content = $web->cleanOutlineWithParagraphs;
-/**
- * $content ahora contiene:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "p",
- * "content" => "This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example."
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "p",
- * "content" => "There are numerous examples on the website. Please check them out to get more context on how scraping works."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be an example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be the second example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be another example."
- * ]
- * ]
- */
-```
diff --git a/websites/es/examples/paragraphs.md b/websites/es/examples/paragraphs.md
deleted file mode 100644
index 6777585..0000000
--- a/websites/es/examples/paragraphs.md
+++ /dev/null
@@ -1,64 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Content&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Texto de raspado
-
-El raspado de contenido, sobre todo de párrafos, se puede hacer fácilmente usando PHP Scraper. Hay un método dedicado para acceder a los párrafos (`
`) en un sitio web. Los siguientes ejemplos muestran cómo acceder al contenido/textos de un sitio web.
-
-
-## Obtener todos los párrafos
-
-El siguiente ejemplo devolverá una lista de todos los párrafos (etiquetas `
`) del sitio web:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navegue a la página de prueba. Contiene 6 párrafos lorem ipsum
-$web->go('https://test-pages.phpscraper.de/content/paragraphs.html');
-
-// Comprueba el número de párrafos.
-echo "Esta página contiene " . count($web->paragraphs) . " párrafos.\n\n";
-
-// Recorrer los párrafos en bucle
-foreach ($web->paragraphs as $paragraph) {
- echo " - " . $paragraph . "\n";
-}
-
-/**
- * Se imprimirá:
- *
- * Esta página contiene 6 apartados.
- *
- * - Maecenas eget ex sit amet urna porta fermentum at ut dui. Praesent lectus arcu, hendrerit sed mi vel, commodo lacinia velit. Nullam ac velit quis ante tristique scelerisque quis non metus. Pellentesque non aliquam elit, in tincidunt purus. Vestibulum fringilla cursus risus, eget ornare dolor feugiat vitae. Sed non porta lorem, eget ornare diam. Sed quam est, eleifend porttitor imperdiet sit amet, ultricies vel ipsum. Pellentesque mauris mauris, fermentum pretium ex quis, viverra mattis est. Donec laoreet sem nec arcu rhoncus lobortis. Duis id orci vel enim interdum aliquam. Integer eu ex ligula. Ut mattis nisi non malesuada ornare. In elit ligula, ultricies a aliquet eget, dictum sit amet neque. Quisque nulla sem, aliquam id molestie iaculis, consequat at augue. Nullam sollicitudin finibus eros in venenatis. Donec semper sagittis ipsum, et rhoncus magna ultricies eu.
-
- * - Quisque sed dolor ut nunc accumsan lacinia. Suspendisse vel eros faucibus massa feugiat tristique. Nullam vitae scelerisque felis, malesuada hendrerit felis. Quisque eleifend mi lorem, vitae elementum dolor bibendum et. Etiam et faucibus augue. Pellentesque viverra sagittis consequat. Nulla a mollis ex. Sed vel nisl mauris. Nulla consequat dui sed pulvinar interdum. Integer vehicula molestie quam non fringilla. Duis auctor sem ut purus fringilla, in lacinia dui finibus. Nulla rhoncus semper velit, eget semper tellus suscipit eget. Vestibulum massa tellus, tristique sit amet dolor et, ullamcorper porta turpis. Vivamus eget magna lacinia, pretium sem sed, gravida libero.
-
- * - Ut at nunc laoreet, vestibulum mauris in, volutpat magna. Aliquam sodales orci finibus porta convallis. Vestibulum sollicitudin felis a sem consequat luctus. Sed laoreet porta quam, non pharetra massa mattis semper. Phasellus aliquet tortor ut felis scelerisque, non dapibus justo tincidunt. Donec eu pulvinar nisi, sit amet elementum massa. Nulla in odio est. In neque ligula, tristique rhoncus orci eu, egestas ullamcorper est. Integer rhoncus vel quam vel placerat. In nec metus pellentesque elit accumsan molestie eu posuere odio. Sed at eros nec turpis vestibulum eleifend vel in erat. Etiam vel metus faucibus, tempus enim nec, elementum arcu. Ut nec blandit risus. Nam sapien nunc, tristique sit amet facilisis non, maximus a nulla. Pellentesque vel posuere libero.
-
- * - Morbi volutpat purus odio, vitae scelerisque diam consectetur sed. Cras turpis leo, hendrerit in tempus et, convallis in nibh. Mauris molestie facilisis odio, ac egestas erat ultrices pellentesque. Donec interdum leo quis ipsum sagittis venenatis. Etiam scelerisque mi at metus ullamcorper, vitae tristique est tincidunt. Vestibulum ut congue urna, eu sagittis quam. Phasellus eget arcu sapien. In hac habitasse platea dictumst. Morbi ultrices, felis in faucibus ornare, libero augue scelerisque urna, et feugiat nisl est ut velit. Phasellus felis quam, egestas a faucibus nec, dictum eget enim. In tempor a lacus id facilisis.
-
- * - Donec bibendum finibus neque quis viverra. Ut ut nulla venenatis, accumsan purus nec, ullamcorper nisi. Nulla bibendum dui sit amet velit venenatis, eget viverra nibh accumsan. Fusce pharetra, sem eu mattis varius, massa leo eleifend lectus, quis tempor elit ipsum sit amet lorem. Fusce viverra dictum tortor non sodales. Phasellus at lectus quis arcu finibus imperdiet sed eleifend nulla. Donec blandit egestas nibh ac euismod. Curabitur ac pretium eros.
-
- * - Duis pharetra magna at dolor scelerisque, nec luctus ex pretium. Suspendisse a ante lectus. Donec vehicula condimentum turpis, in hendrerit dui suscipit non. Nullam a ultricies felis. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Praesent aliquet varius mauris nec pretium. Vivamus convallis tincidunt nisi, eget scelerisque dolor facilisis vitae. Pellentesque purus neque, sollicitudin sit amet mauris id, posuere posuere mi. Etiam vitae urna vitae turpis volutpat consectetur. Quisque ultrices, ex dapibus hendrerit convallis, diam massa suscipit diam, vulputate pharetra mi orci at massa. Aliquam vel urna tempor, congue justo id, pulvinar lorem. Nulla mattis vitae justo sed molestie. Nunc fermentum fringilla nibh, id fermentum nulla. Sed tincidunt ipsum id est efficitur, molestie aliquet lacus hendrerit. Fusce et nisl eros.
- */
-```
-
-
-## Raspando el primer párrafo
-
-La extracción del primer párrafo de la página web puede hacerse accediendo al primer elemento del array (índice 0).
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/content/paragraphs.html');
-
-echo $web->paragraphs[0];
-/**
- * Imprime el primer párrafo:
- *
- * Maecenas eget ex sit amet urna porta fermentum at ut dui. Praesent lectus arcu, hendrerit sed mi vel, commodo lacinia velit. Nullam ac velit quis ante tristique scelerisque quis non metus. Pellentesque non aliquam elit, in tincidunt purus. Vestibulum fringilla cursus risus, eget ornare dolor feugiat vitae. Sed non porta lorem, eget ornare diam. Sed quam est, eleifend porttitor imperdiet sit amet, ultricies vel ipsum. Pellentesque mauris mauris, fermentum pretium ex quis, viverra mattis est. Donec laoreet sem nec arcu rhoncus lobortis. Duis id orci vel enim interdum aliquam. Integer eu ex ligula. Ut mattis nisi non malesuada ornare. In elit ligula, ultricies a aliquet eget, dictum sit amet neque. Quisque nulla sem, aliquam id molestie iaculis, consequat at augue. Nullam sollicitudin finibus eros in venenatis. Donec semper sagittis ipsum, et rhoncus magna ultricies eu.
- */
-```
-
-Los p-tags vacíos conducirían a cadenas vacías en el array devuelto. Para evitar esto puede llamar a `$web->cleanParagraphs` en su lugar. Esto filtrará los párrafos vacíos y sólo devolverá los que tengan contenido. Para acceder al primer párrafo con contenido utilice `$web->cleanParagraphs[0]`.
diff --git a/websites/es/examples/scrape-header-tags.md b/websites/es/examples/scrape-header-tags.md
deleted file mode 100644
index d5a18a0..0000000
--- a/websites/es/examples/scrape-header-tags.md
+++ /dev/null
@@ -1,153 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Header%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Raspado de etiquetas de cabecera
-
-Las etiquetas de cabecera suelen contener información útil sobre una página web y cómo encaja en la estructura general del sitio web del que forma parte. Los siguientes ejemplos muestran cómo acceder a determinadas piezas de información de la etiqueta `
` y a colecciones en torno a ellas.
-
-
-## Charset
-
-Para acceder al conjunto de caracteres definido, puede utilizar el siguiente método:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de pruebas. Contiene:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Imprimir el charset
-echo $web->charset; // "utf-8"
-```
-
-
-## Viewport
-
-En algunos casos, como el viewport y las meta keywords, la cadena representa un array y se proporcionará como tal:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de la prueba. Contiene:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Obtenga la ventana gráfica como una matriz. Debe contener:
- *
- * [
- * 'width=device-width',
- * 'initial-scale=1',
- * 'shrink-to-fit=no',
- * 'maximum-scale=1',
- * 'user-scalable=no'
- * ],
- */
-var_dump($web->viewport);
-```
-
-Si necesitas acceder a la cadena original "viewport", puedes utilizar `viewportString`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Obtiene el viewport como una cadena. Imprime:
- *
- * "width=device-width, initial-scale=1, shrink-to-fit=no, maximum-scale=1, user-scalable=no"
- */
-echo $web->viewportString;
-```
-
-
-## URL canónica
-
-La URL canónica, si se da, se puede acceder como se muestra en el siguiente ejemplo:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de pruebas. Contiene:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-// Imprimir la URL canónica
-echo $web->canonical; // "https://test-pages.phpscraper.de/navigation/2.html"
-```
-
-::: tip CONSEJO
-Si no se establece un enlace canónico, el método devuelve `null`.
-:::
-
-
-## Content-Type
-
-Para acceder al tipo de contenido puede utilizar la siguiente funcionalidad:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de pruebas. Contiene:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Imprimir el tipo de contenido
-echo $web->contentType; // "text/html; charset=utf-8"
-```
-
-
-## CSFR Token
-
-El método del token CSFR asume que el token se almacena en una etiqueta meta con el nombre "csrf-token". Este es el valor por defecto de Laravel. Puedes acceder a él usando el siguiente código:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de pruebas. Contiene:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Obtener el csrfToken
-echo $web->csrfToken; // "token"
-```
-
-
-## Etiquetas de cabecera combinadas
-
-Si desea acceder a todos los métodos mencionados anteriormente, utilice el método `headers`. Se define como:
-
-```php
-/**
- * @return array
- */
-public function headers()
-{
- return [
- 'charset' => $this->charset(),
- 'contentType' => $this->contentType(),
- 'viewport' => $this->viewport(),
- 'canonical' => $this->canonical(),
- 'csrfToken' => $this->csrfToken(),
- ];
-}
-```
-
-Más información sobre el acceso a las [metaetiquetas](/es/examples/scrape-meta-tags.html).
diff --git a/websites/es/examples/scrape-images.md b/websites/es/examples/scrape-images.md
deleted file mode 100644
index d8f0491..0000000
--- a/websites/es/examples/scrape-images.md
+++ /dev/null
@@ -1,78 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Images&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Raspado de imágenes
-
-Puede que te preguntes cómo raspar fotos, imágenes y otros gráficos de un sitio web utilizando PHPScraper. Al igual que con otras funcionalidades, el scraping de imágenes & fotos de un sitio web sigue un enfoque similar. Todos los gráficos como imágenes, fotos e infografías pueden ser raspados y analizados junto con detalles como atributos de etiquetas o sólo como una lista de URL.
-
-
-## Scrape Image URLs
-
-El siguiente ejemplo analiza una página web en busca de imágenes y devuelve las URLs absolutas de las imágenes como un array.
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue a la página de prueba. Esta página contiene dos imágenes:
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * [
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- *
- * @Nota:
- * Doble porque es dos veces la misma imagen:
- * Una con una ruta relativa y otra con una ruta absoluta.
- * Las rutas relativas se resuelven en rutas absolutas por defecto.
- */
-var_dump($web->images);
-```
-
-::: tip CONSEJO
-Si no se encuentra ninguna imagen, la matriz queda vacía.
-:::
-
-
-## Raspado de imágenes con detalles
-
-Si necesita más detalles, las siguientes peticiones le permiten acceder a los atributos de la etiqueta de la imagen:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'absolute path',
- * 'width' => null,
- * 'height' => null,
- * ],
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'relative path',
- * 'width' => null,
- * 'height' => null,
- * ]
- */
-var_dump($web->imagesWithDetails);
-```
-
-::: tip SEO
-El texto `alt` (con las [palabras clave del contenido](/es/examples/extract-keywords.html)) es utilizado por los motores de búsqueda para las búsquedas basadas en imágenes. Asegúrese de definirlo siempre.
-:::
-
-
-## Atributos de raspado: Alt, Anchura y Altura
-
-Los atributos para `alt`, `width` y `height` están incluidos en el conjunto de datos detallados.
-
-Si necesita más datos, tendrá que ampliar la biblioteca o enviar una incidencia para su consideración.
diff --git a/websites/es/examples/scrape-links.md b/websites/es/examples/scrape-links.md
deleted file mode 100644
index af2c935..0000000
--- a/websites/es/examples/scrape-links.md
+++ /dev/null
@@ -1,120 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Links&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Enlaces de raspado
-
-El scraping de enlaces funciona de forma muy similar al [image scraping](/es/examples/scrape-images.html). Puede recuperar una lista de URL sin ninguna información adicional, así como una lista detallada que contenga `rel`, `target` así como otros atributos.
-
-
-## Lista de enlaces simples
-
-El siguiente ejemplo analiza una página web en busca de enlaces y devuelve un array de URLs absolutas:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de prueba. Contiene 6 enlaces a placekitten.com con diferentes atributos:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/links/target.html');
-
-// Imprime el número de enlaces.
-echo "Esta página contiene " . count($web->links) . " enlaces.\n\n";
-
-// Recorrer los enlaces en bucle
-foreach ($web->links as $link) {
- echo " - " . $link . "\n";
-}
-
-/**
- * Combinado esto se imprimirá:
- *
- * Esta página contiene 6 enlaces.
- *
- * - https://placekitten.com/408/287
- * - https://placekitten.com/444/333
- * - https://placekitten.com/444/321
- * - https://placekitten.com/408/287
- * - https://placekitten.com/444/333
- * - https://placekitten.com/444/321
- */
-```
-
-Si la página no debe contener ningún enlace, se devuelve un array vacío.
-
-
-## Enlaces con detalles
-
-Si necesitas más detalles puedes acceder a ellos de forma similar a como se hace en las imágenes. A continuación se muestra un ejemplo para acceder a los datos detallados del primer enlace de la página:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de prueba. Esta página contiene varios enlaces con diferentes atributos rel. Para ahorrar espacio sólo el primero:
- *
- * external kitten
- */
-$web->go('https://test-pages.phpscraper.de/links/rel.html');
-
-// Obtener el primer enlace de la página.
-$firstLink = $web->linksWithDetails[0];
-
-/**
- * $firstLink contiene ahora:
- *
- * [
- * 'url' => 'https://placekitten.com/432/287',
- * 'protocol' => 'https',
- * 'text' => 'external kitten',
- * 'title' => null,
- * 'target' => null,
- * 'rel' => 'nofollow',
- * 'isNofollow' => true,
- * 'isUGC' => false,
- * 'isNoopener' => false,
- * 'isNoreferrer' => false,
- * ]
- */
-```
-
-Si necesita más datos, tendrá que ampliar la biblioteca o presentar una edición para su consideración.
-
-
-## Enlaces internos y externos
-
-PHPScraper permite devolver sólo enlaces internos o externos. Lo siguiente demuestra ambas cosas:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navega a la página de prueba.
-$web->go('https://test-pages.phpscraper.de/links/base-href.html');
-
-// Obtener la lista de enlaces internos (en el ejemplo se enlaza una imagen)
-var_dump($web->internalLinks);
-/**
- * [
- * 'https://test-pages.phpscraper.de/assets/cat.jpg'
- * ]
- */
-
-// Obtener la lista de enlaces externos
-var_dump($web->externalLinks);
-/**
- * [
- * 'https://placekitten.com/408/287'
- * ]
- */
-```
diff --git a/websites/es/examples/scrape-meta-tags.md b/websites/es/examples/scrape-meta-tags.md
deleted file mode 100644
index adfc65e..0000000
--- a/websites/es/examples/scrape-meta-tags.md
+++ /dev/null
@@ -1,114 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Meta%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Meta Tags
-
-El acceso a la información meta sigue un patrón similar al mostrado anteriormente [etiquetas de cabecera](/es/examples/scrape-header-tags.html). A continuación se muestran algunos ejemplos:
-
-
-## Meta Autor, Descripción e Imagen
-
-El siguiente ejemplo muestra la extracción de tres atributos:
-
-- el Meta Autor,
-- la Meta Descripción y
-- la URL de la meta imagen
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de pruebas. Contiene:
- *
- *
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Obtener la información:
-echo $web->author; // "Lorem ipsum"
-echo $web->description; // "Lorem ipsum dolor etc."
-echo $web->image; // "https://test-pages.phpscraper.de/assets/cat.jpg"
-```
-
-
-## Meta Keywords
-
-La meta etiqueta de palabras clave es naturalmente una matriz y será dividida para su conveniencia:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de pruebas. Contiene:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-// Volcar las palabras clave como un array
-var_dump($web->keywords); // ['one', 'two', 'three']
-```
-
-También puede acceder a la cadena de palabras clave original:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-// Imprime las palabras clave en forma de cadena
-echo $web->keywordString; // "one, two, three"
-```
-
-::: tip CONSEJO
-Esto se refiere únicamente a las palabras clave de la metaetiqueta "keyword". También puede [extraer las palabras clave del contenido](/es/examples/extract-keywords.html)) utilizando PHPScraper.
-:::
-
-
-## Meta Etiquetas Combinadas
-
-Si desea acceder a todas las meta propiedades puede utilizar el método `metaTags`. Devuelve los métodos mencionados anteriormente como un array. Se define como:
-
-```php
-/**
- * obtener la meta recogida como un array
- *
- * @return array
- */
-public function metaTags()
-{
- return [
- 'author' => $this->author(),
- 'image' => $this->image(),
- 'keywords' => $this->keywords(),
- 'description' => $this->description(),
- ];
-}
-```
-
-A partir del ejemplo anterior se utilizaría lo siguiente:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-var_dump($web->metaTags);
-/**
- * Contiene:
- *
- * [
- * 'Lorem ipsum',
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ['one', 'two', 'three'],
- * 'Lorem ipsum dolor etc.',
- * ]
- */
-```
-
-
-## Falta de metaetiquetas
-
-Si necesita acceder a otra metapropiedad puede considerar [contribuir](/contributing.html) al paquete o enviando un [issue en GitHub](https://github.com/spekulatius/phpscraper/issues).
diff --git a/websites/es/examples/scrape-social-media-meta-tags.md b/websites/es/examples/scrape-social-media-meta-tags.md
deleted file mode 100644
index 39fdfae..0000000
--- a/websites/es/examples/scrape-social-media-meta-tags.md
+++ /dev/null
@@ -1,103 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Social%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Social Media Meta Tags
-
-El raspado de las etiquetas de compartición de las redes sociales de un sitio web puede realizarse mediante los siguientes métodos. El conjunto exacto de resultados depende de las etiquetas proporcionadas. Se incluyen todas las etiquetas, siempre que estén en el espacio de nombres prefijado (por ejemplo, `twitter:` para Twitter Cards).
-
-
-## Datos de Open-Graph (OG)
-
-Se pueden obtener datos de gráficos abiertos:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegar a la página de la prueba. La página contiene:
- *
- *
- *
- *
- *
- *
- *
- *
- *
- * @see https://test-pages.phpscraper.de/og/example.html
- */
-$web->go('https://test-pages.phpscraper.de/og/example.html');
-
-// Debería imprimirse 'Lorem Ipsum'
-echo $web->openGraph['og:title'];
-
-// Debería imprimir "Lorem ipsum dolor etc.
-echo $web->openGraph['og:description'];
-
-// Todo el conjunto:
-$data = $web->openGraph;
-
-/**
- * $data ahora contiene:
- *
- * [
- * 'og:site_name' => 'Lorem ipsum',
- * 'og:type' => 'website',
- * 'og:title' => 'Lorem Ipsum',
- * 'og:description' => 'Lorem ipsum dolor etc.',
- * 'og:url' => 'https://test-pages.phpscraper.de/meta/lorem-ipsum.html',
- * 'og:image' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- */
-```
-
-::: tip CONSEJO
-Si no se encuentran datos, el array se devolverá vacío.
-:::
-
-
-## Twitter Card
-
-El análisis de la Twitter Card funciona de forma similar:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue a la página de prueba. La página contiene la siguiente tarjeta de Twitter:
- *
- *
- *
- *
- *
- *
- *
- *
- * @see https://test-pages.phpscraper.de/twittercard/example.html
- */
-$web->go('https://test-pages.phpscraper.de/twittercard/example.html');
-
-// Debería imprimirse 'summary_large_image'
-echo $web->twitterCard['twitter:card'];
-
-// Debería imprimirse 'Lorem Ipsum'
-echo $web->twitterCard['twitter:title'];
-
-// Todo el conjunto.
-$data = $web->twitterCard;
-
-/**
- * $data contiene ahora:
- *
- * [
- * 'twitter:card' => 'summary_large_image',
- * 'twitter:title' => 'Lorem Ipsum',
- * 'twitter:description' => 'Lorem ipsum dolor etc.',
- * 'twitter:url' => 'https://test-pages.phpscraper.de/meta/lorem-ipsum.html',
- * 'twitter:image' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- */
-```
-
-De forma similar a Open Graph, la matriz estará vacía si no se han encontrado etiquetas de Twitter Card.
diff --git a/websites/es/examples/scrape-website-title.md b/websites/es/examples/scrape-website-title.md
deleted file mode 100644
index 6ebe3b4..0000000
--- a/websites/es/examples/scrape-website-title.md
+++ /dev/null
@@ -1,89 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scrape%20Website%20Title&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Raspando el título de un sitio web
-
-Raspar el título de un sitio web es sencillo. Los siguientes ejemplos muestran cómo funciona utilizando PHPScraper.
-
-
-## Ejemplo simple
-
-Ejemplo muy simple de cómo raspar el título de un sitio web:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navegue a la página de prueba - ésta sí contiene una etiqueta de título "Lorem Ipsum"
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Contiene:
- *
- * Lorem Ipsum
- */
-
-// Obtener el título. Esto devolverá: "Lorem Ipsum"
-var_dump($web->title);
-```
-
-
-## Falta el título
-
-Se devolverá `null` si falta el título:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navega a la página de prueba - ésta no contiene una etiqueta de título.
-$web->go('https://test-pages.phpscraper.de/meta/missing.html');
-
-// Obtener el título. Esto devolverá null.
-var_dump($web->title);
-```
-
-Nota: Este es el comportamiento por defecto: Si no se encuentra una etiqueta porque falta en el HTML fuente, se devolverá `null`. Si un elemento iterable está vacío (por ejemplo, si se extraen imágenes de una página sin imágenes), se devolverá un array vacío.
-
-
-## Caracteres especiales
-
-Cargar el título de un sitio web con la diéresis alemana
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navegue hasta la página de pruebas. Contiene:
- *
- * A page with plenty of German umlaute everywhere (ä ü ö)
- */
-$web->go('https://test-pages.phpscraper.de/meta/german-umlaute.html');
-
-// Imprime el título: "A page with plenty of German umlaute everywhere (ä ü ö)"
-echo $web->title;
-```
-
-Debería funcionar de forma similar con cualquier carácter UTF-8.
-
-
-## Entidades HTML
-
-Las entidades HTML deben resolverse
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navega hasta la página de la prueba. Contiene:
- *
- * Cat & Mouse
- */
-$web->go('https://test-pages.phpscraper.de/meta/html-entities.html');
-
-// Imprime el título: "Cat & Mouse"
-echo $web->title;
-```
-
-::: tip CONSEJO
-Se han tenido en cuenta las entidades y los caracteres especiales en toda la biblioteca. Si encuentra un lugar donde no funcionan como se espera, por favor, plantee un [problema](https://github.com/spekulatius/PHPScraper/issues).
-:::
diff --git a/websites/es/misc/show-case.md b/websites/es/misc/show-case.md
deleted file mode 100644
index 4fbc4d1..0000000
--- a/websites/es/misc/show-case.md
+++ /dev/null
@@ -1,7 +0,0 @@
-# Show Case
-
-Además de los [tutoriales](/es/misc/tutorials.html), estas bibliotecas y paquetes de composición usan PHPScraper. Puede revisar el código para obtener más información sobre los casos de uso particulares.
-
-- [datlechin/flarum-link-preview](https://github.com/datlechin/flarum-link-preview): Vista previa del enlace para Flarum Boards.
-
-Si desea agregar su proyecto, envíe un PR.
\ No newline at end of file
diff --git a/websites/es/misc/sponsors.md b/websites/es/misc/sponsors.md
deleted file mode 100644
index 8e60430..0000000
--- a/websites/es/misc/sponsors.md
+++ /dev/null
@@ -1,13 +0,0 @@
-# Sponsors
-
-PHP Scraper es compatible con:
-
-
-
-## Convertirse en patrocinador
-
-Gracias por su interés en convertirse en patrocinador de PHP Scraper. PHP Scraper ofrece paquetes de patrocinio personalizados según sus necesidades. Por favor [contacte](https://peterthaleikis.com/contact) para discutir los detalles.
-
-## Soporte Comercial
-
-El soporte para aplicaciones comerciales, licencias comerciales, desarrollo personalizado, y similares puede ser [discutido](https://peterthaleikis.com/contact). Estaremos encantados de apoyar su proyecto.
diff --git a/websites/es/misc/support.md b/websites/es/misc/support.md
deleted file mode 100644
index a311a7b..0000000
--- a/websites/es/misc/support.md
+++ /dev/null
@@ -1,13 +0,0 @@
-# Apoyo
-
-## Más ejemplos
-
-Si necesita más ejemplos, consulte los [tests](https://github.com/spekulatius/phpscraper/tree/master/tests). Estos contienen otros ejemplos de cómo raspar datos de sitios web.
-
-## Bugs y otros problemas
-
-Si observa algún error o problema de naturaleza similar, por favor, plantee una [cuestión en GitHub](https://github.com/spekulatius/PHPScraper/issues). No olvides incluir la información detallada para replicar el problema.
-
-## Soporte comercial
-
-El soporte para aplicaciones comerciales, licencias comerciales, desarrollo personalizado, etc. puede ser [discutido](https://peterthaleikis.com/contact).
diff --git a/websites/es/misc/tutorials.md b/websites/es/misc/tutorials.md
deleted file mode 100644
index 46c49b1..0000000
--- a/websites/es/misc/tutorials.md
+++ /dev/null
@@ -1,7 +0,0 @@
-# PHP Scraping Tutorials
-
-Los siguientes tutoriales utilizan PHPScraper y podrían ayudar a aprender más sobre las diversas formas de utilizar PHPScraper.
-
-*Próximamente*
-
-Por favor, tenga en cuenta que los tutoriales no están revisados y pueden estar desactualizados.
\ No newline at end of file
diff --git a/websites/examples/custom-selectors.md b/websites/examples/custom-selectors.md
deleted file mode 100644
index 4f35477..0000000
--- a/websites/examples/custom-selectors.md
+++ /dev/null
@@ -1,85 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHPScraper:%20Scraping%20Custom%20Elements&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Custom xPath Selectors
-
-While PHP Scraper supports various simple and xPath-free options to access content you are free to use xPath selectors.
-
-The following examples of custom selectors should be seen as a starting point for any custom information you need to scrape.
-
-::: tip
-If you are struggling with xPath, you might find [this cheatsheet](https://devhints.io/xpath) useful.
-:::
-
-
-## Select an element using the ID attribute
-
-The following example shows how to use an xPath selector with an ID. The result will be the text of the element via `->text()`:
-
-```php
-// Init and load the test page.
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/content/selectors.html');
-
-// Select `->text()` using an ID.
-echo $web->filter("//*[@id='by-id']")->text(); // "Content by ID"
-```
-
-::: tip
-This example uses `->text()` to get the textual content. You can also sub-select items on the same [html5](https://github.com/Masterminds/html5-php) element.
-:::
-
-
-## Select elements by tag name
-
-Selecting elements by tags is shown below. The result will be an array containing the text of the elements:
-
-```php
-// Init and load the test page.
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/content/selectors.html');
-
-// Filter using the ID
-echo $web->filter("//h1")->text(); // "Selector Tests (h1)"
-
-// Select single string using first and chain `->text()`
-echo $web->filterFirst("//h1")->text(); // 'Selector Tests (h1)'
-
-// Select as array using `filterTexts`:
-echo $web->filterTexts("//h1"); // ['Selector Tests (h1)']
-```
-
-::: tip
-While SEO best practices recommend having only one `
`-tag per page, it is still technically possible to have multiple. To ensure you are able to scrap any number of headings this method will return a list instead of a string.
-:::
-
-
-## Select elements using a CSS class
-
-Using a CSS class to select elements is, of course, possible too. Similarly to the tag selection, the result will be an array containing the text of the elements:
-
-```php
-// Init and load the test page.
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/content/selectors.html');
-
-// Filter using the CSS class
-echo $web->filter("//*[@class='by-class']"); // "Selector Tests"
-```
-
-## Troubleshooting
-
-When using custom selectors, PHPScraper hands you the full power of Guotte. You will also receive all errors directly from Guotte instead of PHPScraper (for now).
-
-Below are some common errors while working with custom xPaths:
-
-### `PHP Fatal error: Uncaught InvalidArgumentException: The current node list is empty.`
-
-This will happen if your current selection is empty: No element was found matching your query. You might need to adjust your query to select elements.
-
-### `PHP Warning: DOMXPath::query(): Invalid expression`
-
-This means your xPath is incorrect. Usually, this error occurs in `vendor/symfony/dom-crawler/Crawler.php on line 919`.
-
-Make sure to format the xPath query correctly. The examples above show the required format, including the Asterix: `//*[...]`.
diff --git a/websites/examples/extract-keywords.md b/websites/examples/extract-keywords.md
deleted file mode 100644
index 6ad2885..0000000
--- a/websites/examples/extract-keywords.md
+++ /dev/null
@@ -1,122 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Extract%20Keywords&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Extract Keywords
-
-While scraping content is often enough, sometimes you require to extract significant terms and phrases (keywords) from this content. PHPScraper allows you to extract the keywords of the website directly. For this it uses:
-
-- the title of the website,
-- the meta tags,
-- all headings,
-- the paragraphs on the page,
-- link anchors and link titles as well as
-- title attributes on images
-
-While these keyword phrases are extracted it doesn't mean the page actually ranks for these keywords. The final decision on which keywords a web-page ranks is with the search engine.
-
-The following example will return a list of all keywords extracted from the web-page:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigate to the test page.
-// It contains 3 paragraphs from the English Wikipedia article for "lorem ipsum"
-$web->go('https://test-pages.phpscraper.de/content/keywords.html');
-
-// Check the number of keywords.
-$keywords = $web->contentKeywords;
-echo "This page contains at least " . count($keywords) . " keywords/phrases.\n\n";
-
-// Loop through the keywords
-foreach ($keywords as $keyword) {
- echo " - " . $keyword . "\n";
-}
-
-/**
- * Will print out:
- *
- * This page contains at least 40 keywords/phrases.
- *
- * [...]
- * - graphic
- * - improper latin
- * - introduced
- * - keyword extraction tests
- * - letraset transfer sheets
- * - lorem ipsum
- * - lorem ipsum php rake library lorem ipsum
- * - lorem ipsum text
- * - make
- * - malorum
- * - microsoft word
- * - mid-1980s
- * - nonsensical
- * - page
- * - paragraphs
- * - philosopher cicero
- * - php rake library
- * - popular word processors including pages
- * - popularized
- * - removed
- * - roman statesman
- * - source
- * [...]
- */
-```
-
-::: tip
-The default language (locale) for this is `en_US`. Other languages can be passed as a parameter. This currently works only for a selection of languages. Check this [list](https://github.com/Donatello-za/rake-php-plus#currently-supported-languages) for further information.
-:::
-
-
-## Scoring of Keywords
-
-Not every keyword has the same weight in the ranking-algorithms of search engines. A mix of several factors and SEO-signals decides on the weight a search engine assigns to a word. Frequency of words, length of the texts, and variations such as synonyms can lead to different weighting.
-
-PHPScraper allows you to get an indication of keyword weights in the form of scores:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigate to the test page.
-// It contains 3 paragraphs from the English Wikipedia article for "lorem ipsum"
-$web->go('https://test-pages.phpscraper.de/content/keywords.html');
-
-// Check the number of keywords.
-$keywords = $web->contentKeywordsWithScores;
-echo "This page contains at least " . count($keywords) . " keywords/phrases.\n\n";
-
-// Loop through the keywords
-foreach ($keywords as $keyword => $score) {
- echo sprintf(" - %s (%s)\n", $keyword, $score);
-}
-
-/**
- * Will print out:
- *
- * This page contains at least 40 keywords/phrases.
- *
- * [...]
- * - 1960s (1.0)
- * - added (1.0)
- * - adopted lorem ipsum (11.0)
- * - advertisements (1.0)
- * - aldus employed (4.0)
- * - corrupted version (4.0)
- * - graphic (1.0)
- * - improper latin (4.0)
- * - introduced (1.0)
- * - keyword extraction tests (9.0)
- * - test (1.0)
- * - microsoft word (5.3333333333333)
- * - english wikipedia (4.0)
- * - lorem ipsum (8.0)
- * - lorem ipsum text (11.0)
- * [...]
- */
-```
-
-::: tip
-The PHP-functions [similar_text](https://www.php.net/manual/en/function.similar-text.php) and [levenshtein](https://www.php.net/manual/en/function.levenshtein.php) can help you identify and merge similar keywords as well as typo variations of keywords. [Keyword Merge](https://github.com/spekulatius/keyword-merge) is a composer package to help sorting out similar keywords.
-:::
diff --git a/websites/examples/headings.md b/websites/examples/headings.md
deleted file mode 100644
index 77d998b..0000000
--- a/websites/examples/headings.md
+++ /dev/null
@@ -1,124 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Headings&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Headings
-
-Heading can be useful to get an idea of the content on a website. The following example shows how to scrape:
-
- - A single Heading
- - All headings of a particular level (e.g. `
`)
- - All headings on a page
-
-
-## Scrape Single Heading
-
-Scraping a single heading is easy and be done following this example:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- * Outline Test
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-// Print the H1 heading
-echo $web->h1[0]; // "Outline Test"
-```
-
-::: tip
-The [website title](/examples/scrape-website-title.html) and heading 1 (`
`) can be different. Make sure you retrieve the correct one.
-:::
-
-
-## Headings by Level
-
-There might be cases, in which all headings of a particular level should be retrieved. The example below shows how to do so:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-/**
- * Return the h3 headings:
- *
- * [
- * 'Example 1',
- * 'Example 2',
- * 'Example 3'
- * ]
- */
-$web->h3;
-```
-
-If no headings are found, the array is left empty.
-
-
-## All Headings on a Page
-
-To access all headings on a page, you can do so by accessing the different levels from 1 to 6. Or, alternatively, you can access all at once:
-
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. This page contains:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-/**
- * $headings contains now:
- *
- * [
- * [
- * 'We are testing here!'
- * ],
- * [
- * 'Examples'
- * ],
- * [
- * 'Example 1',
- * 'Example 2',
- * 'Example 3',
- * ],
- * [],
- * [],
- * []
- * ]
- */
-$web->headings;
-```
-
-As you can see, this doesn't contain any information about the structure the headings are in. It's purely to know which headings exist. If you like to have an [outline](/examples/outline.html) you will need use the related methods.
diff --git a/websites/examples/lists.md b/websites/examples/lists.md
deleted file mode 100644
index 6b4a4a2..0000000
--- a/websites/examples/lists.md
+++ /dev/null
@@ -1,71 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Lists&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Lists
-
-Scraping lists follows a similar approach as other scraping with PHPScraper:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. This page contains:
- *
- *
)
- *
- * [
- * "type" => "ul",
- * "children" => ... // List of childNodes
- * "children_plain" =>
- * [
- * "Unordered list item 1"
- * "Unordered list item 2"
- * "Unordered list item with HTML"
- * ]
- * ]
- */
-var_dump($web->unorderedLists);
-
-
-/**
- * Only ordered lists ()
- *
- * [
- * "type" => "ul",
- * "children" => ... // List of childNodes
- * "children_plain" =>
- * [
- * "Ordered list item 1"
- * "Ordered list item 2"
- * "Ordered list item with HTML"
- * ]
- * ]
- */
-var_dump($web->orderedLists);
-
-
-// Both lists combined (as above)
-var_dump($web->lists);
-```
-
-::: warning Nested Lists
-At the moment, this doesn't handle nested lists well. Nested lists are included in the result as `children` to allow further processing.
-:::
diff --git a/websites/examples/navigation.md b/websites/examples/navigation.md
deleted file mode 100644
index 12081f6..0000000
--- a/websites/examples/navigation.md
+++ /dev/null
@@ -1,59 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Navigate%20while%20Scraping&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Navigation
-
-While PHPScraper is mostly intended to parse websites and collect information, you can also use it to navigate websites. Below are examples of ways to *surf* around a website.
-
-
-## Navigation using URLs
-
-You can navigate to any URL. These URLs usually come from the [parsed links](/examples/scrape-links.html).
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// We start on test page #1.
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-// Print the title to see if we actually at the right page...
-echo $web->h1[0]; // 'Page #1'
-
-
-// We navigate to the test page #2 using the absolute URL.
-$web->clickLink('https://test-pages.phpscraper.de/navigation/2.html');
-
-// Print the title to see if we actually at the right page...
-echo $web->h1[0]; // 'Page #2'
-```
-
-
-## Navigation using Anchor Texts
-
-On a website you can *click* on links using their anchor texts:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// We start on test page #1.
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-/**
- * This page contains:
- *
- * 2 relative
- */
-
-// Print the title to see if we actually at the right page...
-echo $web->h1[0]; // 'Page #1'
-
-
-// We navigate to the test page #2 using the text it has on the page.
-$web->clickLink('2 relative');
-
-// Print the title to see if we actually at the right page...
-echo $web->h1[0]; // 'Page #2'
-```
-
-This basic functionality should allow you to navigate websites.
diff --git a/websites/examples/outline.md b/websites/examples/outline.md
deleted file mode 100644
index f476699..0000000
--- a/websites/examples/outline.md
+++ /dev/null
@@ -1,215 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scrape%20Content%20Outline&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Outline Extraction
-
-While you might only want to access the [`headings`](/examples/headings.html), for example, the number of headings it might not always be enough. In some cases, you might need to identify the actual structure of the content. For these use cases you might want to consider one of these methods:
-
- - `outline` works similar as the previously mentioned `headings` method. It also returns all headings, but it keeps the structure of the original document in place and provides the heading levels (e.g. `h1`) alone with the output.
-
- - `outlineWithParagraphs` works similar as `outline` does, the difference is that this call also includes the paragraphs.
-
- - `cleanOutlineWithParagraphs` works similar as `outlineWithParagraphs` does, the difference any empty HTML tags are removed.
-
-The following examples should help to understand the functionality better. There are dedicated methods for [keyword extraction](/examples/extract-keywords.html) available.
-
-
-## Extract the Outline
-
-The outline of the content allows you build an index of the document. The following example builds a markdown version of the headings in the requested document:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. This page contains:
- *
- *
We are testing here!
- * [...]
- *
- *
Examples
- * [...]
- *
- *
Example 1
- * [...]
- *
- *
Example 2
- * [...]
- *
- *
Example 3
- * [...]
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-/**
- * $outline will be set to contains:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ]
- * ]
- */
-$outline = $web->outline;
-```
-
-
-## Extract the Outline with Paragraphs
-
-The following method works in a similar manner as `outline`, but it also includes any paragraphs as part of the returned array:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. This page contains:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-
-$content = $web->outlineWithParagraphs;
-/**
- * $content now contains:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "p",
- * "content" => "This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example."
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "p",
- * "content" => "There are numerous examples on the website. Please check them out to get more context on how scraping works."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be an example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be the second example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be another example."
- * ], [
- * "tag" => "p",
- * "content" => ""
- * ]
- * ]
- */
-```
-
-
-## Extract the cleaned up Outline with Paragraphs
-
-The following method works in a similar manner as `outlineWithParagraphs`, but it doesn't include any empty empty headings or paragraphs as part of the returned array:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. This page contains:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-
-$content = $web->cleanOutlineWithParagraphs;
-/**
- * $content now contains:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "p",
- * "content" => "This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example."
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "p",
- * "content" => "There are numerous examples on the website. Please check them out to get more context on how scraping works."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be an example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be the second example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be another example."
- * ]
- * ]
- */
-```
diff --git a/websites/examples/paragraphs.md b/websites/examples/paragraphs.md
deleted file mode 100644
index 500615a..0000000
--- a/websites/examples/paragraphs.md
+++ /dev/null
@@ -1,64 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Content&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Text
-
-Scraping content, mostly paragraphs, can be done easily using PHP Scraper. There is a dedicated method to access the paragraphs (`
`) on a website. The following examples show how to access the content/texts on a website.
-
-
-## Getting all Paragraphs
-
-The following example will return a list of all paragraphs (`
`-tags) on the website:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigate to the test page. It contains 6 "lorem ipsum" paragraphs:
-$web->go('https://test-pages.phpscraper.de/content/paragraphs.html');
-
-// Check the number of paragraphs:
-echo "This page contains " . count($web->paragraphs) . " paragraphs.\n\n";
-
-// Loop through the paragraphs:
-foreach ($web->paragraphs as $paragraph) {
- echo " - " . $paragraph . "\n";
-}
-
-/**
- * Will print out:
- *
- * This page contains 6 paragraphs.
- *
- * - Maecenas eget ex sit amet urna porta fermentum at ut dui. Praesent lectus arcu, hendrerit sed mi vel, commodo lacinia velit. Nullam ac velit quis ante tristique scelerisque quis non metus. Pellentesque non aliquam elit, in tincidunt purus. Vestibulum fringilla cursus risus, eget ornare dolor feugiat vitae. Sed non porta lorem, eget ornare diam. Sed quam est, eleifend porttitor imperdiet sit amet, ultricies vel ipsum. Pellentesque mauris mauris, fermentum pretium ex quis, viverra mattis est. Donec laoreet sem nec arcu rhoncus lobortis. Duis id orci vel enim interdum aliquam. Integer eu ex ligula. Ut mattis nisi non malesuada ornare. In elit ligula, ultricies a aliquet eget, dictum sit amet neque. Quisque nulla sem, aliquam id molestie iaculis, consequat at augue. Nullam sollicitudin finibus eros in venenatis. Donec semper sagittis ipsum, et rhoncus magna ultricies eu.
-
- * - Quisque sed dolor ut nunc accumsan lacinia. Suspendisse vel eros faucibus massa feugiat tristique. Nullam vitae scelerisque felis, malesuada hendrerit felis. Quisque eleifend mi lorem, vitae elementum dolor bibendum et. Etiam et faucibus augue. Pellentesque viverra sagittis consequat. Nulla a mollis ex. Sed vel nisl mauris. Nulla consequat dui sed pulvinar interdum. Integer vehicula molestie quam non fringilla. Duis auctor sem ut purus fringilla, in lacinia dui finibus. Nulla rhoncus semper velit, eget semper tellus suscipit eget. Vestibulum massa tellus, tristique sit amet dolor et, ullamcorper porta turpis. Vivamus eget magna lacinia, pretium sem sed, gravida libero.
-
- * - Ut at nunc laoreet, vestibulum mauris in, volutpat magna. Aliquam sodales orci finibus porta convallis. Vestibulum sollicitudin felis a sem consequat luctus. Sed laoreet porta quam, non pharetra massa mattis semper. Phasellus aliquet tortor ut felis scelerisque, non dapibus justo tincidunt. Donec eu pulvinar nisi, sit amet elementum massa. Nulla in odio est. In neque ligula, tristique rhoncus orci eu, egestas ullamcorper est. Integer rhoncus vel quam vel placerat. In nec metus pellentesque elit accumsan molestie eu posuere odio. Sed at eros nec turpis vestibulum eleifend vel in erat. Etiam vel metus faucibus, tempus enim nec, elementum arcu. Ut nec blandit risus. Nam sapien nunc, tristique sit amet facilisis non, maximus a nulla. Pellentesque vel posuere libero.
-
- * - Morbi volutpat purus odio, vitae scelerisque diam consectetur sed. Cras turpis leo, hendrerit in tempus et, convallis in nibh. Mauris molestie facilisis odio, ac egestas erat ultrices pellentesque. Donec interdum leo quis ipsum sagittis venenatis. Etiam scelerisque mi at metus ullamcorper, vitae tristique est tincidunt. Vestibulum ut congue urna, eu sagittis quam. Phasellus eget arcu sapien. In hac habitasse platea dictumst. Morbi ultrices, felis in faucibus ornare, libero augue scelerisque urna, et feugiat nisl est ut velit. Phasellus felis quam, egestas a faucibus nec, dictum eget enim. In tempor a lacus id facilisis.
-
- * - Donec bibendum finibus neque quis viverra. Ut ut nulla venenatis, accumsan purus nec, ullamcorper nisi. Nulla bibendum dui sit amet velit venenatis, eget viverra nibh accumsan. Fusce pharetra, sem eu mattis varius, massa leo eleifend lectus, quis tempor elit ipsum sit amet lorem. Fusce viverra dictum tortor non sodales. Phasellus at lectus quis arcu finibus imperdiet sed eleifend nulla. Donec blandit egestas nibh ac euismod. Curabitur ac pretium eros.
-
- * - Duis pharetra magna at dolor scelerisque, nec luctus ex pretium. Suspendisse a ante lectus. Donec vehicula condimentum turpis, in hendrerit dui suscipit non. Nullam a ultricies felis. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Praesent aliquet varius mauris nec pretium. Vivamus convallis tincidunt nisi, eget scelerisque dolor facilisis vitae. Pellentesque purus neque, sollicitudin sit amet mauris id, posuere posuere mi. Etiam vitae urna vitae turpis volutpat consectetur. Quisque ultrices, ex dapibus hendrerit convallis, diam massa suscipit diam, vulputate pharetra mi orci at massa. Aliquam vel urna tempor, congue justo id, pulvinar lorem. Nulla mattis vitae justo sed molestie. Nunc fermentum fringilla nibh, id fermentum nulla. Sed tincidunt ipsum id est efficitur, molestie aliquet lacus hendrerit. Fusce et nisl eros.
- */
-```
-
-
-## Scrape the First Paragraph
-
-Scraping the first paragraph of the website can be done by accessing the first element of the array (index 0).
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/content/paragraphs.html');
-
-echo $web->paragraphs[0];
-/**
- * Prints the first paragraph:
- *
- * Maecenas eget ex sit amet urna porta fermentum at ut dui. Praesent lectus arcu, hendrerit sed mi vel, commodo lacinia velit. Nullam ac velit quis ante tristique scelerisque quis non metus. Pellentesque non aliquam elit, in tincidunt purus. Vestibulum fringilla cursus risus, eget ornare dolor feugiat vitae. Sed non porta lorem, eget ornare diam. Sed quam est, eleifend porttitor imperdiet sit amet, ultricies vel ipsum. Pellentesque mauris mauris, fermentum pretium ex quis, viverra mattis est. Donec laoreet sem nec arcu rhoncus lobortis. Duis id orci vel enim interdum aliquam. Integer eu ex ligula. Ut mattis nisi non malesuada ornare. In elit ligula, ultricies a aliquet eget, dictum sit amet neque. Quisque nulla sem, aliquam id molestie iaculis, consequat at augue. Nullam sollicitudin finibus eros in venenatis. Donec semper sagittis ipsum, et rhoncus magna ultricies eu.
- */
-```
-
-Empty p-tags would lead to empty strings in the returned array. To avoid this you can call `$web->cleanParagraphs` instead. This will filter empty paragraphs and only return those with content. To access the first paragraph with content use `$web->cleanParagraphs[0]`.
diff --git a/websites/examples/parse-csv-json-and-xml-files.md b/websites/examples/parse-csv-json-and-xml-files.md
deleted file mode 100644
index 3268ca9..0000000
--- a/websites/examples/parse-csv-json-and-xml-files.md
+++ /dev/null
@@ -1,150 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scrape%20Common%20File%20Types&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape CSV, XML and JSON
-
-PHPScraper can process common plain file types such as `csv`, `json`, `xml` from strings or URLs for you. Most functionality described below works for all three types. Special cases are noted. The following topics are covered:
-
-[[toc]]
-
-
-## Parsing of CSV/XML/JSON strings
-
-If you have a string that represents a CSV, XML or JSON, PHPScraper can assist in validating and parsing it:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Parse a JSON string
-$json = $web->parseJson($jsonString);
-
-// Parse an XML string
-$xml = $web->parseXml($xmlString);
-
-// Parse a CSV string
-$csv = $web->parseCsv($csvString);
-```
-
-This can be useful when chaining steps or accessing embedded elements such as schema data.
-
-
-## Fetching and Parsing of CSV/XML/JSON URLs
-
-PHPScraper can assist with fetching and parsing the contents of remote resources (URLs) containing JSON-, CSV- or XML data:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Fetches URL and parses contents to JSON.
-$json = $web
- ->parseJson('https://test-pages.phpscraper.de/index.json');
-
-// Fetches URL and parses contents to XML.
-$xml = $web
- ->parseXml('https://test-pages.phpscraper.de/sitemap.xml');
-
-// Fetches URL and parses contents into a simple array.
-$csv = $web
- ->parseCsv('https://test-pages.phpscraper.de/test.csv');
-
-// Fetches URL and generates an asso. array (map) with the first line as keys.
-$csv = $web
- ->parseCsvWithHeader('https://test-pages.phpscraper.de/test.csv');
-```
-
-Each of the methods above can be accessed in various ways. Using `parseCsv` as an example, you can use any of the methods as following:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Option 1: Pass in the absolute URL
-$csv = $web
- ->parseCsv('https://test-pages.phpscraper.de/test.csv');
-
-// Option 2: Navigate to a relative URL for parsing.
-$csv = $web
- ->go('https://test-pages.phpscraper.de/meta/feeds.html')
- ->parseCsv('/test.csv');
-
-// Option 3: Navigate with `go` or `clickLink` and call the parser.
-$csv = $web
- ->go('https://test-pages.phpscraper.de/test.csv')
- ->parseCsv();
-```
-
-::: tip Multiple Methods
-The examples above apply to the following methods:
-
-- `parseJson`
-- `parseXml`
-- `parseCsv`
-- `parseCsvWithHeader` (resolves into an asso. array)
-:::
-
-## Parsing a CSV String with Headers
-
-CSV can be parsed into various data structures. PHPScraper comes with two options built-in to parse CSV. Given the following example file:
-
-```bash
-$ curl https://test-pages.phpscraper.de/test.csv
-
-date,value
-1945-02-06,4.20
-1952-03-11,42
-```
-
-The standard parser `parseCsv` returns a simple array with casted values:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-print_r(
- $web->parseCsv('https://test-pages.phpscraper.de/test.csv')
-);
-/**
- * [
- * ['date', 'value'],
- * ['1945-02-06', 4.20],
- * ['1952-03-11', 42],
- * ]
- */
-```
-
-`parseCsvWithHeader` parses the content and uses the first line as headers and returns an associative array (map):
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-print_r(
- $web->parseCsvWithHeader('https://test-pages.phpscraper.de/test.csv')
-);
-
-/**
- * [
- * ['date' => '1945-02-06', 'value' => 4.20],
- * ['date' => '1952-03-11', 'value' => 42],
- * ]
- */
-```
-
-::: tip Type Casting
-Native types such as `int` and `float` are automatically cast to PHP-native types.
-:::
-
-## Providing CSV Parsing Parameters
-
-You might want to define which *separate*, *enclosure*, and *escape* to use. You can do so by passing an options array along:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Direct access:
-$csv = $web
- ->parseCsv('https://test-pages.phpscraper.de/test-custom.csv', '|', '"');
-
-// Alternative syntax using `go` first:
-$csv = $web
- ->go('https://test-pages.phpscraper.de/test.csv')
- ->parseCsv(null, '|', '"');
-```
diff --git a/websites/examples/scrape-feeds.md b/websites/examples/scrape-feeds.md
deleted file mode 100644
index 14a6bdf..0000000
--- a/websites/examples/scrape-feeds.md
+++ /dev/null
@@ -1,131 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scrape%20Feeds&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Feeds
-
-PHPScraper can identify and process feeds (RSS feeds, sitemaps, etc.) for you. The following feed-specific features are implemented:
-
-[[toc]]
-
-
-## Identify RSS Feed URLs
-
-Websites can define RSS feeds in the head section of their markup. PHPScraper allows to identify any RSS feeds noted on the current page using `rssUrls`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- *
- *
- */
-
-print_r(
- $web
- ->go('https://test-pages.phpscraper.de/meta/feeds.html')
- ->rssUrls
-);
-
-/**
- * [
- * 'https://test-pages.phpscraper.de/absolute.xml',
- * 'https://test-pages.phpscraper.de/relative.xml'
- * ]
- */
-```
-
-
-## Parse RSS feeds
-
-The `rss()`-method can be used to parse RSS feeds. If called without any parameter `rssUrls` will be used:
-
-```php
-// Init and go to any page of the domain. This sets the base URL.
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/feeds.html');
-
-// Same as `$web->rss(...$web->rssUrls)`
-$rss = $web->rss();
-```
-
-You can also parse RSS feeds by passing one or more URLs in:
-
-```php
-// Single URL.
-$rss = $web->rss($web->rssUrls[0]);
-
-// Multiple URLs
-$rss = $web->rss(
- 'https://example.com/feed_1.xml',
- 'https://example.com/feed_2.xml'
-);
-```
-
-This result contains an array structure with selected properties. The array structure contains instances of `DataTransferObjects\FeedEntry` with properties for `link` and `title`.
-
-::: tip Complete Details
-If you need all details, please fallback on `$web->rssRaw(...)`. It can be called like `$web->rss(...)` and returns an array structure.
-:::
-
-
-## Parse XML Sitemaps
-
-You can parse XML sitemaps using `sitemap()`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Get the sitemap for the current website (if it exists).
- * This assumes the default URL `/sitemap.xml` is used.
- *
- * @throws \Exception (e.g. network).
- */
-$sitemap = $web
- ->go('https://example.com')
- ->sitemap();
-
-// You can pass in the desired URL:
-$sitemap = $web->sitemap('https://example.com/custom_sitemap.xml');
-```
-
-This result contains only selected properties. It returns an array of `DataTransferObjects\FeedEntry` with the `link` property.
-
-::: tip Complete Details
-If you need all details, please fallback on `$web->sitemapRaw(...)`. It can be called like `$web->sitemap()` and returns an array structure.
-:::
-
-
-## Parse Static Search Indexes
-
-You can parse static search indexes using `searchIndex()`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Get the search index for the current website (if it exists).
-// This assumes the default URL `/index.json` is used.
-$searchIndex = $web
- ->go('https://example.com')
- ->searchIndex();
-
-// You can pass in the desired URL:
-$searchIndex = $web->searchIndex('https://example.com/custom_index.json');
-```
-
-**This result contains only selected properties.** It returns an array of `DataTransferObjects\FeedEntry` with properties `link`, `title`, and `description`.
-
-::: tip Complete Details
-If you need all details, please fallback on `$web->searchIndexRaw(...)`. It can be called like `$web->searchIndex()` and returns an array structure.
-:::
\ No newline at end of file
diff --git a/websites/examples/scrape-header-tags.md b/websites/examples/scrape-header-tags.md
deleted file mode 100644
index 83075ff..0000000
--- a/websites/examples/scrape-header-tags.md
+++ /dev/null
@@ -1,153 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Header%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Header Tags
-
-The header tags often contain useful information about a web-page and how it fits into the overall structure of the website it is part of. The following examples show how to access particular pieces of information from the `
` and collections around these.
-
-
-## Charset
-
-To access the defined charset, you can use the following method:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Print the charset
-echo $web->charset; // "utf-8"
-```
-
-
-## Viewport
-
-In some cases, such as the viewport and the meta keywords, the string is representing an array and will be provided as such:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Returns the viewport as an array. For the example it contains:
- *
- * [
- * 'width=device-width',
- * 'initial-scale=1',
- * 'shrink-to-fit=no',
- * 'maximum-scale=1',
- * 'user-scalable=no'
- * ],
- */
-var_dump($web->viewport);
-```
-
-If you need to access the original "viewport"-string, you can use `viewportString`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Returns the viewport as a string. It prints:
- *
- * "width=device-width, initial-scale=1, shrink-to-fit=no, maximum-scale=1, user-scalable=no"
- */
-echo $web->viewportString;
-```
-
-
-## Canonical URL
-
-The canonical URL, if given, can be accessed as shown in the example below:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-// Print the canonical URL:
-echo $web->canonical; // "https://test-pages.phpscraper.de/navigation/2.html"
-```
-
-::: tip
-If no canonical link is set, the method returns `null`.
-:::
-
-
-## Content-Type
-
-To access the content type you can use the following functionality:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Print the contentType:
-echo $web->contentType; // "text/html; charset=utf-8"
-```
-
-
-## CSFR Token
-
-The CSFR token method assumes that the token is stored in a meta tag with the name "csrf-token". This is the default for Laravel. You can access it using the following code:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Returns the csrfToken:
-echo $web->csrfToken; // "token"
-```
-
-
-## Combined Header Tags
-
-You can use the `headers`-method if you want all of the above-mentioned methods. It is defined as:
-
-```php
-/**
- * @return array
- */
-public function headers()
-{
- return [
- 'charset' => $this->charset(),
- 'contentType' => $this->contentType(),
- 'viewport' => $this->viewport(),
- 'canonical' => $this->canonical(),
- 'csrfToken' => $this->csrfToken(),
- ];
-}
-```
-
-More information on accessing the [meta tags](/examples/scrape-meta-tags.html).
diff --git a/websites/examples/scrape-images.md b/websites/examples/scrape-images.md
deleted file mode 100644
index f5473af..0000000
--- a/websites/examples/scrape-images.md
+++ /dev/null
@@ -1,88 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Images&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Images
-
-You might wonder how to scrape photos, images and other graphics from a website using PHPScraper. As with other functionality, scraping the images & photos from a website follows a similar approach. All graphics such as images, photos, and infographics can be scraped and parsed along with details such as tag attributes or only as an URL list.
-
-
-## Scrape Image URLs
-
-The following example parses a web-page for images and returns absolute image URLs as an array.
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. This page contains two images:
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * [
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- *
- * @note
- * The URL is listed twice because it's included twice on the page:
- * Once with a relative path and once with an absolute path.
- * The relative paths are resolved to absolute paths by default.
- */
-var_dump($web->images);
-```
-
-::: tip
-If no images are found, the array remains empty. You can download images using `$web->fetchAsset(...)`.
-:::
-
-
-## Scrape Images with Details
-
-If you are in need of more details the following requests allows you to access attributes of the image tag:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'absolute path',
- * 'width' => null,
- * 'height' => null,
- * ],
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'relative path',
- * 'width' => null,
- * 'height' => null,
- * ]
- */
-var_dump($web->imagesWithDetails);
-```
-
-::: tip SEO
-The `alt`-text (with the [keywords of the content](/examples/extract-keywords.html)) is used by search engines for image-based searches. Make sure to always define it.
-:::
-
-
-## Scrape Attributes: Alt, Width and Height
-
-The attributes for `alt`, `width` and `height` are included in the detailed data set.
-
-If you require more data, you will either need to extend the library or submit an issue for consideration.
-
-
-## Fetching Assets
-
-If you want to fetch assets, you can do so using `fetchAsset`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$sharingImage = $web->fetchAsset($web->image);
-```
diff --git a/websites/examples/scrape-links.md b/websites/examples/scrape-links.md
deleted file mode 100644
index 6327332..0000000
--- a/websites/examples/scrape-links.md
+++ /dev/null
@@ -1,120 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Links&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Links
-
-The scraping of links works very similar to [image scraping](/examples/scrape-images.html). You can retrieve a list of URL without any additional information as well as a detailed list containing `rel`, `target` as well as other attributes.
-
-
-## Simple Link List
-
-The following example parses a web-page for any links and returns an array of absolute URLs:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains 6 links to placekitten.com with different attributes:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/links/target.html');
-
-// Print the number of links.
-echo "This page contains " . count($web->links) . " links.\n\n";
-
-// Loop through the links
-foreach ($web->links as $link) {
- echo " - " . $link . "\n";
-}
-
-/**
- * Combined this will print out:
- *
- * This page contains 6 links.
- *
- * - https://placekitten.com/408/287
- * - https://placekitten.com/444/333
- * - https://placekitten.com/444/321
- * - https://placekitten.com/408/287
- * - https://placekitten.com/444/333
- * - https://placekitten.com/444/321
- */
-```
-
-If the page shouldn't contain any links, an empty array is returned.
-
-
-## Links with Details
-
-If you are in need of more details you can access these in a similar way as on the images. Below is an example to access the detailed data of the first link on the page:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. This page contains several links with different rel attributes. To save space only the first one:
- *
- * external kitten
- */
-$web->go('https://test-pages.phpscraper.de/links/rel.html');
-
-// Get the first link on the page.
-$firstLink = $web->linksWithDetails[0];
-
-/**
- * $firstLink contains now:
- *
- * [
- * 'url' => 'https://placekitten.com/432/287',
- * 'protocol' => 'https',
- * 'text' => 'external kitten',
- * 'title' => null,
- * 'target' => null,
- * 'rel' => 'nofollow',
- * 'isNofollow' => true,
- * 'isUGC' => false,
- * 'isNoopener' => false,
- * 'isNoreferrer' => false,
- * ]
- */
-```
-
-If you require more data, you will either need to extend the library or submit an issue for consideration.
-
-
-## Internal Links and External Links
-
-PHPScraper allows to return only internal or external links. The following demonstrates both:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigate to the test page.
-$web->go('https://test-pages.phpscraper.de/links/base-href.html');
-
-// Get the list of internal links (in the example an image is linked)
-var_dump($web->internalLinks);
-/**
- * [
- * 'https://test-pages.phpscraper.de/assets/cat.jpg'
- * ]
- */
-
-// Get the list of external links
-var_dump($web->externalLinks);
-/**
- * [
- * 'https://placekitten.com/408/287'
- * ]
- */
-```
diff --git a/websites/examples/scrape-meta-tags.md b/websites/examples/scrape-meta-tags.md
deleted file mode 100644
index 1e998ff..0000000
--- a/websites/examples/scrape-meta-tags.md
+++ /dev/null
@@ -1,114 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Meta%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Meta Tags
-
-Accessing the meta information follows a similar pattern as the previously shown [header tags](/examples/scrape-header-tags.html). Below are examples to explain:
-
-
-## Meta Author, Description and Image
-
-The following example shows the extraction of three attributes:
-
-- the Meta Author,
-- the Meta Description and
-- the Meta Image URL
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- *
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Get the information:
-echo $web->author; // "Lorem ipsum"
-echo $web->description; // "Lorem ipsum dolor etc."
-echo $web->image; // "https://test-pages.phpscraper.de/assets/cat.jpg"
-```
-
-
-## Meta Keywords
-
-The keywords meta-tag is naturally an array and will be split for your convenience:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-// Dump the keywords as an array
-var_dump($web->keywords); // ['one', 'two', 'three']
-```
-
-Alternatively, you can access the original keyword string:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-// Print the keywords as string
-echo $web->keywordString; // "one, two, three"
-```
-
-::: tip
-This refers only to the keywords in the "keyword" meta-tag. You can also [extract the content keywords](/examples/extract-keywords.html)) using PHPScraper.
-:::
-
-
-## Combined Meta Tags
-
-You can use the `metaTags`-method if you would like to access all meta properties. It returns the above-mentioned methods as an array. It is defined as:
-
-```php
-/**
- * get the meta collected as an array
- *
- * @return array
- */
-public function metaTags()
-{
- return [
- 'author' => $this->author(),
- 'image' => $this->image(),
- 'keywords' => $this->keywords(),
- 'description' => $this->description(),
- ];
-}
-```
-
-From the example above it would be used as follows:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-var_dump($web->metaTags);
-/**
- * Contains:
- *
- * [
- * 'Lorem ipsum',
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ['one', 'two', 'three'],
- * 'Lorem ipsum dolor etc.',
- * ]
- */
-```
-
-
-## Missing Meta Tags
-
-This is similar to the PHP-native function [`get_meta_tags`](https://www.php.net/manual/en/function.get-meta-tags.php) but might not cover all use cases. If you need to access another meta property, please read the [contribution guidelines](/contributing.html) before opening a pull request or submitting an [issue on GitHub](https://github.com/spekulatius/phpscraper/issues).
diff --git a/websites/examples/scrape-social-media-meta-tags.md b/websites/examples/scrape-social-media-meta-tags.md
deleted file mode 100644
index 24e7836..0000000
--- a/websites/examples/scrape-social-media-meta-tags.md
+++ /dev/null
@@ -1,103 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Social%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Social Media Meta Tags
-
-Scraping social media sharing tags from a website can be done using the following methods. The exact result set depends on the provided tags. All tags are included, as long as these are in the prefixed namespace (e.g. `twitter:` for Twitter Cards).
-
-
-## Open-Graph (OG) Data
-
-Fetching open-graph data can be done:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. Page contains:
- *
- *
- *
- *
- *
- *
- *
- *
- *
- * @see https://test-pages.phpscraper.de/og/example.html
- */
-$web->go('https://test-pages.phpscraper.de/og/example.html');
-
-// Prints 'Lorem Ipsum':
-echo $web->openGraph['og:title'];
-
-// Prints 'Lorem ipsum dolor etc.':
-echo $web->openGraph['og:description'];
-
-// The whole OpenGraph-set:
-$data = $web->openGraph;
-
-/**
- * $data now contains:
- *
- * [
- * 'og:site_name' => 'Lorem ipsum',
- * 'og:type' => 'website',
- * 'og:title' => 'Lorem Ipsum',
- * 'og:description' => 'Lorem ipsum dolor etc.',
- * 'og:url' => 'https://test-pages.phpscraper.de/meta/lorem-ipsum.html',
- * 'og:image' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- */
-```
-
-::: tip
-If not data was found, the array will be returned empty.
-:::
-
-
-## Twitter Card
-
-Parsing the Twitter Card works similarly:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. The page contains the following Twitter Card:
- *
- *
- *
- *
- *
- *
- *
- *
- * @see https://test-pages.phpscraper.de/twittercard/example.html
- */
-$web->go('https://test-pages.phpscraper.de/twittercard/example.html');
-
-// Should print out 'summary_large_image'
-echo $web->twitterCard['twitter:card'];
-
-// Should print out 'Lorem Ipsum'
-echo $web->twitterCard['twitter:title'];
-
-// The whole set.
-$data = $web->twitterCard;
-
-/**
- * $data contains now:
- *
- * [
- * 'twitter:card' => 'summary_large_image',
- * 'twitter:title' => 'Lorem Ipsum',
- * 'twitter:description' => 'Lorem ipsum dolor etc.',
- * 'twitter:url' => 'https://test-pages.phpscraper.de/meta/lorem-ipsum.html',
- * 'twitter:image' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- */
-```
-
-In similar fashion to Open Graph, the array will be empty if no Twitter Card tags have been found.
diff --git a/websites/examples/scrape-website-title.md b/websites/examples/scrape-website-title.md
deleted file mode 100644
index 26950cd..0000000
--- a/websites/examples/scrape-website-title.md
+++ /dev/null
@@ -1,89 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scrape%20Website%20Title&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scrape Website Title
-
-Scraping the title from a website is simple. The following examples show how it works using PHPScraper.
-
-
-## Simple Example
-
-Very simple example of how to scrape the title of a website:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigate to the test page - this one does contain a title-tag "Lorem Ipsum"
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Contains:
- *
- * Lorem Ipsum
- */
-
-// Fetch the title. This will return: "Lorem Ipsum"
-var_dump($web->title);
-```
-
-
-## Missing Title
-
-`null` will be returned if the title is missing:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Navigate to the test page - this one doesn't contain a title-tag.
-$web->go('https://test-pages.phpscraper.de/meta/missing.html');
-
-// Fetch the title. This will return null.
-var_dump($web->title);
-```
-
-Note: This is the default behaviour: If a tag wasn't found because it's missing in the source HTML, `null` will be returned. If an iteratable item is empty (e.g. scraping images from a page without images), an empty array will be returned.
-
-
-## Special Characters
-
-Load a website title with German Umlaute
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. It contains:
- *
- * A page with plenty of German umlaute everywhere (ä ü ö)
- */
-$web->go('https://test-pages.phpscraper.de/meta/german-umlaute.html');
-
-// Print the title: "A page with plenty of German umlaute everywhere (ä ü ö)"
-echo $web->title;
-```
-
-It should work similarly with any UTF-8 characters.
-
-
-## HTML Entities
-
-HTML Entities should be resolved
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Navigate to the test page. Contains:
- *
- * Cat & Mouse
- */
-$web->go('https://test-pages.phpscraper.de/meta/html-entities.html');
-
-// Print the title: "Cat & Mouse"
-echo $web->title;
-```
-
-::: tip
-Entities and special characters have been considered throughout the library. If you find a place where these don't work as expected, please raise an [issue](https://github.com/spekulatius/PHPScraper/issues).
-:::
diff --git a/websites/fr/README.md b/websites/fr/README.md
deleted file mode 100644
index 208c12a..0000000
--- a/websites/fr/README.md
+++ /dev/null
@@ -1,174 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP%20Scraper:%20Rendre%20sa%20simplicité%20au%20Scraping%20et%20au%20Crawling&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-PHP Scraper: Rendre sa simplicité au Scraping et au Crawling
-============================================================
-
-![PHP Scraper: Rendre sa simplicité au Scraping et au Crawling](logo-light.png)
-
-*de [Peter Thaleikis](https://peterthaleikis.com)*
-
-PHPScraper est une bibliothèque de scraper pour PHP, construite avec la notion de simplicité en tête. Il s'agit d'un wrapper fait à partir de quelques grandes bibliothèques PHP pour rendre l'accès au web plus facile.
-
-Les exemples valent mieux que mille mots. Jetez-y un coup d'œil !
-
-::: tip Note
-Ce site de documentation en français est en cours d'élaboration. Veuillez élever un PR sur GitHub si vous trouvez des erreurs. Merci !
-:::
-
-
-L'idée 💡️
-----------
-
-Accéder aux sites web et collecter les informations de base du web est trop complexe. Cette enveloppe autour de [Goutte](https://github.com/FriendsOfPHP/Goutte) rend les choses plus faciles. Il vous épargne XPath et autres, en vous donnant un accès direct à tout ce dont vous avez besoin. Le scraping Web avec PHP: un nouveau concept.
-
-
-Supporters 💪️
--------------
-
-Ce projet est sponsorisé par:
-
-
-
-Vous souhaitez devenir sponsor de ce projet? [Écrivez-moi](https://peterthaleikis.com/contact).
-
-
-Exemples
---------
-
-Voici quelques exemples de ce que la bibliothèque de scraping web peut faire à ce stade:
-
-### Scrape Meta Information:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient:
- *
- *
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Obtenir l'information:
-echo $web->author; // "Lorem ipsum"
-echo $web->description; // "Lorem ipsum dolor etc."
-echo $web->image; // "https://test-pages.phpscraper.de/assets/cat.jpg"
-```
-
-La plupart des autres informations sont accessibles directement, sous forme de chaîne ou de tableau..
-
-
-### Racler du contenu, comme des images:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Cette page contient deux images:
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-var_dump($web->imagesWithDetails);
-/**
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'absolute path',
- * 'width' => null,
- * 'height' => null,
- * ],
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'relative path',
- * 'width' => null,
- * 'height' => null,
- * ]
- */
-```
-
-Certaines informations *optionnellement* sont retournées comme un tableau avec des détails. Pour cet exemple, une simple liste d'images est disponible en utilisant `$web->images` aussi. Cela devrait faciliter votre travail de scraping web.
-
-Vous trouverez plus d'exemples de code dans les exemples individuels et dans les tests.
-
-
-Installation
-------------
-
-L'installation se fait généralement en utilisant [Composer](https://getcomposer.org).
-
-### Installation avec Composer
-
-```bash
-composer require spekulatius/phpscraper
-```
-
-Une fois l'installation terminée, le paquet sera récupéré par l'autoloader de Composer. Dans les applications et frameworks PHP typiques tels que Laravel ou Symfony, vous pouvez commencer à faire du scraping maintenant. Vous pouvez maintenant utiliser n'importe lequel des exemples mentionnés ou des exemples dans le dossier `tests/`.
-
-### Utilisation dans les projets VanillaPHP
-
-Si vous construisez un projet VanillaPHP, vous devrez inclure l'autoloader dans votre script au début de votre script PHP:
-
-```php
-require 'vendor/autoload.php';
-```
-
-Si vous utilisez un framework tel que Laravel, Symfony, Laminas, Phalcon ou CakePHP, vous n'aurez pas besoin de cette étape. L'autoloader est automatiquement inclus.
-
-
-Configuration
--------------
-
-Une configuration supplémentaire est facultative. Voici les options correctement disponibles.
-
-### Support des proxys
-
-Si vous avez besoin de proxys, vous pouvez configurer le support des proxys avec `setConfig` :
-
-```php
-$web->setConfig(['proxy' => 'http://user:password@127.0.0.1:3128']);
-```
-
-### Timeout
-
-Vous pouvez définir le `timeout` en utilisant `setConfig`:
-
-```php
-$web->setConfig(['timeout' => 15]);
-```
-
-La mise à `0` (zéro) du délai d'attente le désactivera.
-
-### Désactivation de SSL
-
-Bien que cela ne soit pas recommandé, il peut être nécessaire de désactiver les contrôles SSL. Vous pouvez le faire en utilisant :
-
-```php
-$web->setConfig(['disable_ssl' => true]);
-```
-
-Vous pouvez appeler `setConfig` plusieurs fois. Il stocke la configuration et la fusionne avec les paramètres précédents. Ceci doit être gardé à l'esprit dans le cas improbable d'une utilisation pour annuler des valeurs.
-
-
-Vous avez trouvé un bug et l'avez corrigé ? C'est génial !
-----------------------------------
-
-Avant de commencer, familiarisez-vous avec les éléments suivants [directives de contribution](/contributing.html). Si vous avez des questions, n'hésitez pas à nous contacter.
-
-
-Tests: S'assurer que ça marche !
-----------------------------
-
-Le code est grossièrement couvert par des tests de bout en bout. Pour cela, des pages web simples sont hébergées sur *https://test-pages.phpscraper.de/*, chargées et analysées à l'aide de [PHPUnit](https://phpunit.de/). Ces tests peuvent également servir d'exemples - voir `tests/` !
-
-Ceci étant dit, il y a probablement des edge cases qui ne fonctionnent pas et qui peuvent causer des problèmes. Si vous en trouvez un, veuillez signaler un bug sur GitHub.
-
-Dédicaces
-----------------------------
-Remerciements à mon ami [@yesnoornext](https://twitter.com/yesnoornext) pour son aide précieuse sur ce projet.
diff --git a/websites/fr/apis/alibaba.md b/websites/fr/apis/alibaba.md
deleted file mode 100644
index 93f16b1..0000000
--- a/websites/fr/apis/alibaba.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# API pour scraper Alibaba/AliExpress
-
-L'équipe à l'origine de PHP Scraper s'efforce de fournir des API commerciales pour divers cas d'utilisation courants ainsi que pour des plateformes. Ces API ne sont pas auto-hébergées. Vous n'aurez pas à vous soucier de la rotation des IP/proxies, ni à utiliser un navigateur sans tête comme Puppeteer. Un simple appel à l'API vous permettra d'obtenir toutes les informations requises. Les services seront fournis sur la base d'une structure tarifaire attractive dépendant de l'utilisation.
-
-Pour Alibaba, nous envisageons la mise en œuvre d'une API avec la portée suivante.
-
-## Endpoints supportés proposés
-
-- Recherche de produits par mot-clé
-- Obtenir des informations sur les produits
-
-::: tip Conseil
-Veuillez noter que cette liste de points d'accès aux API n'est *pas* définitive et qu'elle est susceptible de changer.
-:::
-
-## Support de la plateforme
-
-Grâce à l'approche consistant à utiliser une API gérée, les utilisateurs n'ont plus à se soucier de la rotation des proxies, des problèmes de mise à l'échelle et des pannes. En outre, un large éventail de plateformes est pris en charge. Vous pouvez facilement l'intégrer à NodeJS, Python (sans requêtes ou beautifulsoap), Golang, etc. Toute plateforme qui permet d'exécuter des requêtes GET peut être programmée pour demander des données à ce service.
diff --git a/websites/fr/apis/amazon.md b/websites/fr/apis/amazon.md
deleted file mode 100644
index e71853c..0000000
--- a/websites/fr/apis/amazon.md
+++ /dev/null
@@ -1,22 +0,0 @@
-# API pour scraper Amazon
-
-L'équipe à l'origine de PHP Scraper s'efforce de fournir des API commerciales pour divers cas d'utilisation courants ainsi que pour des plateformes. Ces API ne sont pas auto-hébergées. Vous n'aurez pas à vous soucier de la rotation des IPs/proxies, ni à utiliser un navigateur sans tête comme Puppeteer. Un simple appel à l'API vous permettra d'obtenir toutes les informations requises. Les services seront fournis sur la base d'une structure tarifaire attractive dépendant de l'utilisation.
-
-Pour Amazon, nous envisageons la mise en œuvre d'une API avec la portée suivante.
-
-## Points de terminaison supportés proposés
-
-- Obtenir des informations sur le produit
-- Obtenir des recommandations
-- Obtenir des informations sur les évaluations
-- Obtenir des informations sur les vendeurs
-- Obtenir tous les prix des vendeurs
-- Recherche de produits par mot-clé ou par identifiant de vendeur
-
-::: tip Conseil
-Veuillez noter que cette liste de points d'accès aux API n'est *pas* définitive et qu'elle est susceptible de changer.
-:::
-
-## Support de la plate-forme
-
-Grâce à l'approche consistant à utiliser une API gérée, les utilisateurs n'ont plus à se soucier de la rotation des proxies, des problèmes de mise à l'échelle et des pannes. En outre, un large éventail de plateformes est pris en charge. Vous pouvez facilement intégrer NodeJS, Python (sans requests ou beautifulsoap), Golang, etc. Toute plateforme qui permet d'exécuter des requêtes GET peut être programmée pour demander des données à ce service.
diff --git a/websites/fr/apis/etsy.md b/websites/fr/apis/etsy.md
deleted file mode 100644
index dfb8510..0000000
--- a/websites/fr/apis/etsy.md
+++ /dev/null
@@ -1,22 +0,0 @@
-# API pour scraper Etsy
-
-L'équipe à l'origine de PHP Scraper s'efforce de fournir des API commerciales pour divers cas d'utilisation courants ainsi que pour des plateformes. Ces API ne sont pas auto-hébergées. Vous n'aurez pas à vous soucier de la rotation des IPs/proxies, ni à utiliser un navigateur sans tête comme Puppeteer. Un simple appel à l'API vous permettra d'obtenir toutes les informations requises. Les services seront fournis sur la base d'une structure tarifaire attractive dépendant de l'utilisation.
-
-Pour Etsy, nous envisageons la mise en œuvre d'une API avec la portée suivante.
-
-## Endpoints supportés proposés
-
-- Obtenir des informations sur le produit
-- Obtenir des recommandations
-- Obtenir des informations sur les évaluations
-- Obtenir des informations sur les vendeurs
-- Obtenir tous les prix des vendeurs
-- Recherche de produits par mot-clé ou par identifiant de vendeur
-
-::: tip Conseil
-Veuillez noter que cette liste de points d'accès aux API n'est *pas* définitive et qu'elle est susceptible de changer.
-:::
-
-## Support de la plate-forme
-
-Grâce à l'approche consistant à utiliser une API gérée, les utilisateurs n'ont plus à se soucier de la rotation des proxies, des problèmes de mise à l'échelle et des pannes. En outre, un large éventail de plateformes est pris en charge. Vous pouvez facilement intégrer NodeJS, Python (sans requests ou beautifulsoap), Golang, etc. Toute plateforme qui permet d'exécuter des requêtes GET peut être programmée pour demander des données à ce service.
diff --git a/websites/fr/apis/facebook.md b/websites/fr/apis/facebook.md
deleted file mode 100644
index 90a69b6..0000000
--- a/websites/fr/apis/facebook.md
+++ /dev/null
@@ -1,28 +0,0 @@
-# API pour scraper Facebook
-
-L'équipe à l'origine de PHP Scraper s'efforce de fournir des API commerciales pour divers cas d'utilisation courants ainsi que pour des plateformes. Ces API ne sont pas auto-hébergées. Vous n'aurez pas à vous soucier de la rotation des IPs/proxies, de l'utilisation d'un navigateur sans tête tel que Puppeteer. Un simple appel à l'API vous permettra d'obtenir toutes les informations requises. Les services seront fournis sur la base d'une structure tarifaire attractive dépendant de l'utilisation.
-
-Pour Facebook, nous envisageons la mise en œuvre d'une API avec la portée suivante.
-
-## Endpoints pris en charge proposés
-
-- Utilisateur: profil utilisateur public
-- Utilisateur: autres comptes sociaux
-- Utilisateur: Liste d'amis
-- Utilisateur: Images
-- Utilisateur: Messages de localisation
-- Utilisateur: Messages de l'utilisateur
-- Groupes publics et groupes privés avec clé: Profil du groupe public
-- Groupes publics et groupes privés avec clé: Liste des membres
-- Public Groupes et groupes privés avec clé: Images
-- Public Groupes et groupes privés avec clé: Messages de localisation
-- Public Groupes et groupes privés avec clé: Messages
-- Messages: Détails du message public (y compris les commentaires, les "likes", les "likers", etc.)
-
-::: tip Conseil
-Veuillez noter que cette liste de points d'accès aux API n'est *pas* définitive et qu'elle est susceptible de changer.
-:::
-
-## Support de la plate-forme
-
-Grâce à l'approche consistant à utiliser une API gérée, les utilisateurs n'ont plus à se soucier de la rotation des proxies, des problèmes de mise à l'échelle et des pannes. En outre, un large éventail de plateformes est pris en charge. Vous pouvez facilement intégrer NodeJS, Python (sans requests ou beautifulsoap), Golang, etc. Toute plateforme qui permet d'exécuter des requêtes GET peut être programmée pour demander des données à ce service.
diff --git a/websites/fr/apis/instagram.md b/websites/fr/apis/instagram.md
deleted file mode 100644
index b32c5e0..0000000
--- a/websites/fr/apis/instagram.md
+++ /dev/null
@@ -1,34 +0,0 @@
-# API pour scraper Instagram
-
-L'équipe derrière PHP Scraper travaille à fournir des API commerciales pour divers cas d'utilisation courants ainsi que pour des plateformes. Ces API ne sont pas auto-hébergées. Vous n'aurez pas à vous soucier de la rotation des IP/proxies, de l'utilisation d'un navigateur sans tête tel que Puppeteer. Un simple appel à l'API vous permettra d'obtenir toutes les informations requises. Les services seront fournis sur la base d'une structure tarifaire attractive dépendant de l'utilisation.
-
-Pour Instagram, nous envisageons la mise en œuvre d'une API avec la portée suivante.
-
-## Endpoints supportés proposés
-
-- Utilisateur: détails du profil
-- Utilisateur: Faits marquants
-- Utilisateur: Messages
-- Utilisateur: Messages marqués
-- Utilisateur: Messages publics
-- Utilisateur: Suiveurs
-- Utilisateur: Obtenir des histoires
-- Utilisateur: Statut actuel
-- Utilisateur: Autres comptes sociaux
-- Messages publics: Commentaires
-- Messages publics: J'aime
-- Story downloader avec conversion en mp4, mp3, etc.
-- Messages avec hashtag
-- Messages sur l'emplacement
-- Recherche d'emplacement
-- Détails du message
-- Profils connexes
-- Recherche
-
-::: tip Conseil
-Veuillez noter que cette liste de points d'accès aux API n'est *pas* définitive et qu'elle est susceptible de changer.
-:::
-
-## Support de la plate-forme
-
-Grâce à l'approche consistant à utiliser une API gérée, les utilisateurs n'ont plus à se soucier de la rotation des proxies, des problèmes de mise à l'échelle et des pannes. En outre, un large éventail de plateformes est pris en charge. Vous pouvez facilement intégrer NodeJS, Python (sans requests ou beautifulsoap), Golang, etc. Toute plateforme qui permet d'exécuter des requêtes GET peut être programmée pour demander des données à ce service.
diff --git a/websites/fr/apis/linkedin.md b/websites/fr/apis/linkedin.md
deleted file mode 100644
index 6938630..0000000
--- a/websites/fr/apis/linkedin.md
+++ /dev/null
@@ -1,21 +0,0 @@
-# API pour scraper LinkedIn
-
-L'équipe à l'origine de PHP Scraper s'efforce de fournir des API commerciales pour divers cas d'utilisation courants ainsi que pour des plateformes. Ces API ne sont pas auto-hébergées. Vous n'aurez pas à vous soucier de la rotation des IP/proxies, ni à utiliser un navigateur sans tête tel que Puppeteer. Un simple appel à l'API vous permettra d'obtenir toutes les informations requises. Les services seront fournis sur la base d'une structure tarifaire attractive dépendant de l'utilisation.
-
-Pour LinkedIn, nous envisageons la mise en œuvre d'une API avec la portée suivante.
-
-## Endpoints supportés proposés
-
-- Utilisateur: Détails du profil
-- Utilisateur: Messages
-- Post: Téléchargeur et convertisseur de vidéo.
-- Entreprise: Détails du profil
-- Recherche d'emploi
-
-::: tip Conseil
-Veuillez noter que cette liste de points d'accès aux API n'est *pas* définitive et qu'elle est susceptible de changer.
-:::
-
-## Support de la plate-forme
-
-Grâce à l'approche consistant à utiliser une API gérée, les utilisateurs n'ont plus à se soucier de la rotation des proxies, des problèmes de mise à l'échelle et des pannes. En outre, un large éventail de plateformes est pris en charge. Vous pouvez facilement intégrer NodeJS, Python (sans requests ou beautifulsoap), Golang, etc. Toute plateforme qui permet d'exécuter des requêtes GET peut être programmée pour demander des données à ce service.
diff --git a/websites/fr/apis/target.md b/websites/fr/apis/target.md
deleted file mode 100644
index fd5420f..0000000
--- a/websites/fr/apis/target.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# API pour scraper Target
-
-L'équipe à l'origine de PHP Scraper travaille à la fourniture d'API commerciales pour divers cas d'utilisation courants ainsi que pour des plateformes. Ces API ne sont pas auto-hébergées. Vous n'aurez pas à vous soucier de la rotation des IPs/proxies, ni à utiliser un navigateur sans tête comme Puppeteer. Un simple appel à l'API vous permettra d'obtenir toutes les informations requises. Les services seront fournis sur la base d'une structure tarifaire attractive dépendant de l'utilisation.
-
-Pour Target, nous envisageons la mise en œuvre d'une API avec la portée suivante.
-
-## Endpoints supportés proposés
-
-- Obtenir des détails sur le produit
-- Recherche de produits par mot-clé
-
-::: tip Conseil
-Veuillez noter que cette liste de points d'accès aux API n'est *pas* définitive et qu'elle est susceptible de changer.
-:::
-
-## Support de la plate-forme
-
-Grâce à l'approche consistant à utiliser une API gérée, les utilisateurs n'ont plus à se soucier de la rotation des proxies, des problèmes de mise à l'échelle et des pannes. En outre, un large éventail de plateformes est pris en charge. Vous pouvez facilement intégrer NodeJS, Python (sans requests ou beautifulsoap), Golang, etc. Toute plateforme qui permet d'exécuter des requêtes GET peut être programmée pour demander des données à ce service.
diff --git a/websites/fr/apis/tiktok.md b/websites/fr/apis/tiktok.md
deleted file mode 100644
index 3e1d0a2..0000000
--- a/websites/fr/apis/tiktok.md
+++ /dev/null
@@ -1,21 +0,0 @@
-# API pour scraper TikTok
-
-L'équipe à l'origine de PHP Scraper s'efforce de fournir des API commerciales pour divers cas d'utilisation courants ainsi que pour des plateformes. Ces API ne sont pas auto-hébergées. Vous n'aurez pas à vous soucier de la rotation des IP/proxies, ni à utiliser un navigateur sans tête tel que Puppeteer. Un simple appel à l'API vous permettra d'obtenir toutes les informations requises. Les services seront fournis sur la base d'une structure tarifaire attractive dépendant de l'utilisation.
-
-Pour TikTok, nous envisageons la mise en œuvre d'une API avec la portée suivante.
-
-## Endpoints supportés proposés
-
-- Recherche par Tag
-- Utilisateur: Détails du profil public
-- Utilisateur: Autres comptes sociaux
-- Détails de la vidéo
-- Téléchargement de vidéos avec conversion en mp4, mp3, etc. et sans filigrane
-
-::: tip Conseil
-Veuillez noter que cette liste de points d'accès aux API n'est *pas* définitive et qu'elle est susceptible de changer.
-:::
-
-## Support de la plate-forme
-
-Grâce à l'approche consistant à utiliser une API gérée, les utilisateurs n'ont plus à se soucier de la rotation des proxies, des problèmes de mise à l'échelle et des pannes. En outre, un large éventail de plateformes est pris en charge. Vous pouvez facilement intégrer NodeJS, Python (sans requests ou beautifulsoap), Golang, etc. Toute plateforme qui permet d'exécuter des requêtes GET peut être programmée pour demander des données à ce service.
diff --git a/websites/fr/apis/walmart.md b/websites/fr/apis/walmart.md
deleted file mode 100644
index e6cbf82..0000000
--- a/websites/fr/apis/walmart.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# API pour scraper Walmart
-
-L'équipe à l'origine de PHP Scraper travaille à la fourniture d'API commerciales pour divers cas d'utilisation courants ainsi que pour des plateformes. Ces API ne sont pas auto-hébergées. Vous n'aurez pas à vous soucier de la rotation des IPs/proxies, ni à utiliser un navigateur sans tête comme Puppeteer. Un simple appel à l'API vous permettra d'obtenir toutes les informations requises. Les services seront fournis sur la base d'une structure tarifaire attractive dépendant de l'utilisation.
-
-Pour Walmart, nous envisageons la mise en œuvre d'une API avec la portée suivante.
-
-## Endpoints supportés proposés
-
-- Obtenir des détails sur le produit
-- Recherche de produits par mot-clé
-
-::: tip Conseil
-Veuillez noter que cette liste de points d'accès aux API n'est *pas* définitive et qu'elle est susceptible de changer.
-:::
-
-## Support de la plate-forme
-
-Grâce à l'approche consistant à utiliser une API gérée, les utilisateurs n'ont plus à se soucier de la rotation des proxies, des problèmes de mise à l'échelle et des pannes. En outre, un large éventail de plateformes est pris en charge. Vous pouvez facilement intégrer NodeJS, Python (sans requests ou beautifulsoap), Golang, etc. Toute plateforme qui permet d'exécuter des requêtes GET peut être programmée pour demander des données à ce service.
diff --git a/websites/fr/apis/zalando.md b/websites/fr/apis/zalando.md
deleted file mode 100644
index bafe6fa..0000000
--- a/websites/fr/apis/zalando.md
+++ /dev/null
@@ -1,18 +0,0 @@
-# API pour scraper Zalando
-
-L'équipe à l'origine de PHP Scraper s'efforce de fournir des API commerciales pour divers cas d'utilisation courants ainsi que pour des plateformes. Ces API ne sont pas auto-hébergées. Vous n'aurez pas à vous soucier de la rotation des IP/proxies, ni à utiliser un navigateur sans tête comme Puppeteer. Un simple appel à l'API vous permettra d'obtenir toutes les informations requises. Les services seront fournis sur la base d'une structure tarifaire attractive dépendant de l'utilisation.
-
-Pour Zalando, nous envisageons la mise en œuvre d'une API avec la portée suivante.
-
-## Endpoints supportés proposés
-
-- Obtenir des détails sur le produit
-- Recherche de produits par mot-clé
-
-::: tip Conseil
-Veuillez noter que cette liste de points d'accès aux API n'est *pas* définitive et qu'elle est susceptible de changer.
-:::
-
-## Support de la plate-forme
-
-Grâce à l'approche consistant à utiliser une API gérée, les utilisateurs n'ont plus à se soucier de la rotation des proxies, des problèmes de mise à l'échelle et des pannes. En outre, un large éventail de plateformes est pris en charge. Vous pouvez facilement intégrer NodeJS, Python (sans requests ou beautifulsoap), Golang, etc. Toute plateforme qui permet d'exécuter des requêtes GET peut être programmée pour demander des données à ce service.
diff --git a/websites/fr/examples/extract-keywords.md b/websites/fr/examples/extract-keywords.md
deleted file mode 100644
index 0882531..0000000
--- a/websites/fr/examples/extract-keywords.md
+++ /dev/null
@@ -1,122 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Extract%20Keywords&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Mots clés extraits
-
-Bien que le scraping du contenu soit souvent suffisant, vous avez parfois besoin d'extraire des termes et des phrases spécifiques (mots-clés) dans ce contenu. PHPScraper vous permet d'extraire directement les mots-clés du site web. Pour cela, il utilise:
-
-- le titre du site web,
-- les balises méta,
-- tous les titres,
-- les paragraphes de la page,
-- les ancres et les titres des liens, ainsi que
-- les attributs de titre des images
-
-Si ces mots-clés sont extraits, cela ne signifie pas que la page est effectivement classée pour ces mots-clés. C'est le moteur de recherche qui prend la décision finale quant au classement d'une page Web.
-
-L'exemple suivant renvoie une liste de tous les mots-clés extraits de la page Web:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Naviguer vers la page de test.
-// Elle contient 3 paragraphes de l'article de Wikipédia en anglais pour "lorem ipsum".
-$web->go('https://test-pages.phpscraper.de/content/keywords.html');
-
-// Vérifier le nombre de mots-clés.
-$keywords = $web->contentKeywords;
-echo "Cette page contient au moins " . count($keywords) . " mots-clés/phrases.\n\n";
-
-// Boucle à travers les mots-clés
-foreach ($keywords as $keyword) {
- echo " - " . $keyword . "\n";
-}
-
-/**
- * S'imprimera:
- *
- * Cette page contient au moins 40 mots-clés/expressions.
- *
- * [...]
- * - graphic
- * - improper latin
- * - introduced
- * - keyword extraction tests
- * - letraset transfer sheets
- * - lorem ipsum
- * - lorem ipsum php rake library lorem ipsum
- * - lorem ipsum text
- * - make
- * - malorum
- * - microsoft word
- * - mid-1980s
- * - nonsensical
- * - page
- * - paragraphs
- * - philosopher cicero
- * - php rake library
- * - popular word processors including pages
- * - popularized
- * - removed
- * - roman statesman
- * - source
- * [...]
- */
-```
-
-::: tip Conseil
-La langue (locale) par défaut est `en_US`. D'autres langues peuvent être passées en paramètre. Actuellement, cela ne fonctionne que pour une sélection de langues. Vérifiez ceci [liste](https://github.com/Donatello-za/rake-php-plus#currently-supported-languages) pour de plus amples informations.
-:::
-
-
-## Notation des mots-clés
-
-Tous les mots clés n'ont pas le même poids dans les algorithmes de classement des moteurs de recherche. Un mélange de plusieurs facteurs et signaux de référencement décide du poids qu'un moteur de recherche attribue à un mot. La fréquence des mots, la longueur des textes et les variations telles que les synonymes peuvent entraîner une pondération différente.
-
-PHPScraper vous permet d'obtenir une indication de la pondération des mots-clés sous la forme de scores:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Naviguer vers la page de test.
-// Il contient 3 paragraphes de l'article de Wikipédia en anglais pour "lorem ipsum".
-$web->go('https://test-pages.phpscraper.de/content/keywords.html');
-
-// Vérifier le nombre de mots-clés.
-$keywords = $web->contentKeywordsWithScores;
-echo "Cette page contient au moins " . count($keywords) . " mots-clés/phrases.\n\n";
-
-// Boucle à travers les mots-clés
-foreach ($keywords as $keyword => $score) {
- echo sprintf(" - %s (%s)\n", $keyword, $score);
-}
-
-/**
- * S'affichera:
- *
- * Cette page contient au moins 40 mots-clés/expressions.
- *
- * [...]
- * - 1960s (1.0)
- * - added (1.0)
- * - adopted lorem ipsum (11.0)
- * - advertisements (1.0)
- * - aldus employed (4.0)
- * - corrupted version (4.0)
- * - graphic (1.0)
- * - improper latin (4.0)
- * - introduced (1.0)
- * - keyword extraction tests (9.0)
- * - test (1.0)
- * - microsoft word (5.3333333333333)
- * - english wikipedia (4.0)
- * - lorem ipsum (8.0)
- * - lorem ipsum text (11.0)
- * [...]
- */
-```
-
-::: tip Conseil
-Les fonctions PHP [similar_text](https://www.php.net/manual/en/function.similar-text.php) et [levenshtein](https://www.php.net/manual/en/function.levenshtein.php) peut vous aider à identifier et à fusionner les mots-clés similaires ainsi que les variations typographiques des mots-clés. [Keyword Merge](https://github.com/spekulatius/keyword-merge) est un paquet de compositeurs pour aider à trier les mots-clés similaires.
-:::
diff --git a/websites/fr/examples/headings.md b/websites/fr/examples/headings.md
deleted file mode 100644
index 99b02b3..0000000
--- a/websites/fr/examples/headings.md
+++ /dev/null
@@ -1,124 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Headings&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scraping Headings
-
-Les titres peuvent être utiles pour se faire une idée du contenu d'un site Web. L'exemple suivant montre comment effectuer un scraping:
-
- - Un seul Heading
- - Tous les titres d'un niveau particulier (par exemple, `
`)
- - Tous les titres d'une page
-
-
-## Récupération d'un seul titre
-
-La récupération d'un seul titre est facile et peut être réalisée en suivant cet exemple:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient:
- *
- * Outline Test
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-// Imprimer l'en-tête H1
-echo $web->h1[0]; // "Outline Test"
-```
-
-::: tip Conseil
-Le site [titre du site web](/fr/examples/scrape-website-title.html) et la rubrique 1 (`
`) peuvent être différentes. Assurez-vous que vous récupérez le bon.
-:::
-
-
-## Rubriques par niveau
-
-Il peut arriver que vous souhaitiez récupérer toutes les rubriques d'un niveau particulier. L'exemple ci-dessous vous montre comment faire:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient:
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-/**
- * Obtenir les en-têtes h3:
- *
- * [
- * 'Example 1',
- * 'Example 2',
- * 'Example 3'
- * ]
- */
-$web->h3;
-```
-
-Si aucun titre n'est trouvé, le tableau est laissé vide.
-
-
-## Toutes les rubriques d'une page
-
-Pour accéder à toutes les rubriques d'une page, vous pouvez le faire en accédant aux différents niveaux de 1 à 6. Ou bien, vous pouvez accéder à toutes les rubriques en même temps:
-
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguer vers la page de test. Cette page contient:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-/**
- * $headings contains now:
- *
- * [
- * [
- * 'We are testing here!'
- * ],
- * [
- * 'Examples'
- * ],
- * [
- * 'Example 1',
- * 'Example 2',
- * 'Example 3',
- * ],
- * [],
- * [],
- * []
- * ]
- */
-$web->headings;
-```
-
-Comme vous pouvez le constater, il ne contient aucune information sur la structure des rubriques. Il s'agit uniquement de savoir quelles rubriques existent. Si vous souhaitez avoir une [aperçu](/fr/examples/outline.html) vous devrez utiliser les méthodes correspondantes.
diff --git a/websites/fr/examples/lists.md b/websites/fr/examples/lists.md
deleted file mode 100644
index d8f10bc..0000000
--- a/websites/fr/examples/lists.md
+++ /dev/null
@@ -1,71 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Lists&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scraping Lists
-
-Le scrapping de listes suit une approche similaire aux autres scrappings avec PHPScraper:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguer vers la page de test. Cette page contient:
- *
- *
Example 1: Unordered List
- *
- *
Unordered list item 1
- *
Unordered list item 2
- *
Unordered list item with HTML
- *
- *
- *
Example 2: Ordered List
- *
- *
Ordered list item 1
- *
Ordered list item 2
- *
Ordered list item with HTML
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/lists.html');
-
-/**
- * Seulement les listes non ordonnées (
)
- *
- * [
- * "type" => "ul",
- * "children" => ... // Liste des childNodes
- * "children_plain" =>
- * [
- * "Unordered list item 1"
- * "Unordered list item 2"
- * "Unordered list item with HTML"
- * ]
- * ]
- */
-var_dump($web->unorderedLists);
-
-
-/**
- * Seulement les listes ordonnées ()
- *
- * [
- * "type" => "ul",
- * "children" => ... // Liste des childNodes
- * "children_plain" =>
- * [
- * "Ordered list item 1"
- * "Ordered list item 2"
- * "Ordered list item with HTML"
- * ]
- * ]
- */
-var_dump($web->orderedLists);
-
-
-// Les deux listes combinées (comme ci-dessus)
-var_dump($web->lists);
-```
-
-::: warning Listes imbriquées
-Pour l'instant, le système ne gère pas bien les listes imbriquées. Les listes imbriquées sont incluses dans le résultat en tant que "enfants" pour permettre un traitement ultérieur.
-:::
diff --git a/websites/fr/examples/navigation.md b/websites/fr/examples/navigation.md
deleted file mode 100644
index a2b72bc..0000000
--- a/websites/fr/examples/navigation.md
+++ /dev/null
@@ -1,59 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Navigate%20while%20Scraping&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Navigation
-
-Bien que PHPScraper soit principalement destiné à analyser les sites Web et à collecter des informations, vous pouvez également l'utiliser pour naviguer sur les sites Web. Vous trouverez ci-dessous des exemples de façons de *surfer* sur un site Web.
-
-
-## Navigation à l'aide d'URLs
-
-Vous pouvez naviguer vers n'importe quelle URL. Ces URLs proviennent généralement du [liens analysés](/fr/examples/scrape-links.html).
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Nous commençons sur la page de test #1.
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-// Imprimez le titre pour voir si nous sommes bien à la bonne page...
-echo $web->h1[0]; // 'Page #1'
-
-
-// Nous naviguons vers la page de test n°2 en utilisant l'URL absolue.
-$web->clickLink('https://test-pages.phpscraper.de/navigation/2.html');
-
-// Imprimez le titre pour voir si nous sommes bien à la bonne page...
-echo $web->h1[0]; // 'Page #2'
-```
-
-
-## Navigation à l'aide de textes d'ancrage
-
-Sur un site Web, vous pouvez *cliquer* sur des liens en utilisant leurs textes d'ancrage:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Nous commençons sur la page de test #1.
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-/**
- * Cette page contient:
- *
- * 2 relative
- */
-
-// Imprimez le titre pour voir si nous sommes bien à la bonne page...
-echo $web->h1[0]; // 'Page #1'
-
-
-// Nous naviguons vers la page de test n°2 en utilisant le texte qu'il y a sur la page.
-$web->clickLink('2 relative');
-
-// Imprimez le titre pour voir si nous sommes bien à la bonne page...
-echo $web->h1[0]; // 'Page #2'
-```
-
-Cette fonctionnalité de base devrait vous permettre de naviguer sur les sites web.
diff --git a/websites/fr/examples/outline.md b/websites/fr/examples/outline.md
deleted file mode 100644
index 44ccb26..0000000
--- a/websites/fr/examples/outline.md
+++ /dev/null
@@ -1,215 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scrape%20Content%20Outline&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Outline Extraction
-
-Bien que vous puissiez vouloir accéder uniquement à la [`rubriques`](/fr/examples/headings.html) pour traiter, par exemple, le nombre ou la longueur des titres, ce n'est pas toujours suffisant. Dans certains cas, vous pouvez avoir besoin d'identifier la structure réelle du contenu. Pour ces cas d'utilisation, vous pouvez envisager l'une de ces méthodes:
-
- - `outline` fonctionne de manière similaire à la méthode `headings` mentionnée précédemment. Elle retourne également tous les titres, mais elle garde la structure du document original en place et fournit les niveaux de titres (par exemple `h1`) seuls avec la sortie.
-
- - `outlineWithParagraphs` fonctionne de la même manière que `outline`, la différence est que cet appel inclut également les paragraphes.
-
- - `cleanOutlineWithParagraphs` fonctionne de la même manière que `outlineWithParagraphs`, à la différence que toutes les balises HTML vides sont supprimées.
-
-Les exemples suivants devraient vous aider à mieux comprendre cette fonctionnalité. Il existe des méthodes dédiées pour [extraction de mots-clés](/fr/examples/extract-keywords.html) disponible sur.
-
-
-## Extraire l'Outline
-
-L'Outline Extraction vous permet de construire un index du document. L'exemple suivant construit une version markdown des titres du document demandé:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguer vers la page de test. Cette page contient:
- *
- *
We are testing here!
- * [...]
- *
- *
Examples
- * [...]
- *
- *
Example 1
- * [...]
- *
- *
Example 2
- * [...]
- *
- *
Example 3
- * [...]
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-/**
- * $outline sera défini comme contenant:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ]
- * ]
- */
-$outline = $web->outline;
-```
-
-
-### Extraire le plan avec des paragraphes
-
-La méthode suivante fonctionne de manière similaire à `outline`, mais elle inclut également les paragraphes dans le tableau retourné:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguer vers la page de test. Cette page contient:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-
-$content = $web->outlineWithParagraphs;
-/**
- * $content now contains:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "p",
- * "content" => "This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example."
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "p",
- * "content" => "There are numerous examples on the website. Please check them out to get more context on how scraping works."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be an example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be the second example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be another example."
- * ], [
- * "tag" => "p",
- * "content" => ""
- * ]
- * ]
- */
-```
-
-
-## Extraire le plan nettoyé avec les paragraphes.
-
-La méthode suivante fonctionne de manière similaire à `outlineWithParagraphs`, mais elle n'inclut aucun titre ou paragraphe vide dans le tableau retourné:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguer vers la page de test. Cette page contient:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-
-$content = $web->cleanOutlineWithParagraphs;
-/**
- * $content contient maintenant:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "p",
- * "content" => "This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example."
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "p",
- * "content" => "There are numerous examples on the website. Please check them out to get more context on how scraping works."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be an example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be the second example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be another example."
- * ]
- * ]
- */
-```
diff --git a/websites/fr/examples/paragraphs.md b/websites/fr/examples/paragraphs.md
deleted file mode 100644
index f51f69a..0000000
--- a/websites/fr/examples/paragraphs.md
+++ /dev/null
@@ -1,64 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Content&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scraping Text
-
-La récupération de contenu, principalement des paragraphes, peut être faite facilement en utilisant PHP Scraper. Il existe une méthode dédiée pour accéder aux paragraphes (`
`) d'un site web. Les exemples suivants montrent comment accéder au contenu/textes d'un site web.
-
-
-## Obtenir tous les paragraphes
-
-L'exemple suivant renvoie une liste de tous les paragraphes (balises `
`) du site Web:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Naviguez vers la page de test. Elle contient 6 paragraphes lorem ipsum.
-$web->go('https://test-pages.phpscraper.de/content/paragraphs.html');
-
-// Vérifier le nombre de paragraphes.
-echo "Cette page contient " . count($web->paragraphs) . " paragraphes.\n\n";
-
-// Boucle à travers les paragraphes
-foreach ($web->paragraphs as $paragraph) {
- echo " - " . $paragraph . "\n";
-}
-
-/**
- * S'affichera:
- *
- * Cette page contient 6 paragraphes.
- *
- * - Maecenas eget ex sit amet urna porta fermentum at ut dui. Praesent lectus arcu, hendrerit sed mi vel, commodo lacinia velit. Nullam ac velit quis ante tristique scelerisque quis non metus. Pellentesque non aliquam elit, in tincidunt purus. Vestibulum fringilla cursus risus, eget ornare dolor feugiat vitae. Sed non porta lorem, eget ornare diam. Sed quam est, eleifend porttitor imperdiet sit amet, ultricies vel ipsum. Pellentesque mauris mauris, fermentum pretium ex quis, viverra mattis est. Donec laoreet sem nec arcu rhoncus lobortis. Duis id orci vel enim interdum aliquam. Integer eu ex ligula. Ut mattis nisi non malesuada ornare. In elit ligula, ultricies a aliquet eget, dictum sit amet neque. Quisque nulla sem, aliquam id molestie iaculis, consequat at augue. Nullam sollicitudin finibus eros in venenatis. Donec semper sagittis ipsum, et rhoncus magna ultricies eu.
-
- * - Quisque sed dolor ut nunc accumsan lacinia. Suspendisse vel eros faucibus massa feugiat tristique. Nullam vitae scelerisque felis, malesuada hendrerit felis. Quisque eleifend mi lorem, vitae elementum dolor bibendum et. Etiam et faucibus augue. Pellentesque viverra sagittis consequat. Nulla a mollis ex. Sed vel nisl mauris. Nulla consequat dui sed pulvinar interdum. Integer vehicula molestie quam non fringilla. Duis auctor sem ut purus fringilla, in lacinia dui finibus. Nulla rhoncus semper velit, eget semper tellus suscipit eget. Vestibulum massa tellus, tristique sit amet dolor et, ullamcorper porta turpis. Vivamus eget magna lacinia, pretium sem sed, gravida libero.
-
- * - Ut at nunc laoreet, vestibulum mauris in, volutpat magna. Aliquam sodales orci finibus porta convallis. Vestibulum sollicitudin felis a sem consequat luctus. Sed laoreet porta quam, non pharetra massa mattis semper. Phasellus aliquet tortor ut felis scelerisque, non dapibus justo tincidunt. Donec eu pulvinar nisi, sit amet elementum massa. Nulla in odio est. In neque ligula, tristique rhoncus orci eu, egestas ullamcorper est. Integer rhoncus vel quam vel placerat. In nec metus pellentesque elit accumsan molestie eu posuere odio. Sed at eros nec turpis vestibulum eleifend vel in erat. Etiam vel metus faucibus, tempus enim nec, elementum arcu. Ut nec blandit risus. Nam sapien nunc, tristique sit amet facilisis non, maximus a nulla. Pellentesque vel posuere libero.
-
- * - Morbi volutpat purus odio, vitae scelerisque diam consectetur sed. Cras turpis leo, hendrerit in tempus et, convallis in nibh. Mauris molestie facilisis odio, ac egestas erat ultrices pellentesque. Donec interdum leo quis ipsum sagittis venenatis. Etiam scelerisque mi at metus ullamcorper, vitae tristique est tincidunt. Vestibulum ut congue urna, eu sagittis quam. Phasellus eget arcu sapien. In hac habitasse platea dictumst. Morbi ultrices, felis in faucibus ornare, libero augue scelerisque urna, et feugiat nisl est ut velit. Phasellus felis quam, egestas a faucibus nec, dictum eget enim. In tempor a lacus id facilisis.
-
- * - Donec bibendum finibus neque quis viverra. Ut ut nulla venenatis, accumsan purus nec, ullamcorper nisi. Nulla bibendum dui sit amet velit venenatis, eget viverra nibh accumsan. Fusce pharetra, sem eu mattis varius, massa leo eleifend lectus, quis tempor elit ipsum sit amet lorem. Fusce viverra dictum tortor non sodales. Phasellus at lectus quis arcu finibus imperdiet sed eleifend nulla. Donec blandit egestas nibh ac euismod. Curabitur ac pretium eros.
-
- * - Duis pharetra magna at dolor scelerisque, nec luctus ex pretium. Suspendisse a ante lectus. Donec vehicula condimentum turpis, in hendrerit dui suscipit non. Nullam a ultricies felis. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Praesent aliquet varius mauris nec pretium. Vivamus convallis tincidunt nisi, eget scelerisque dolor facilisis vitae. Pellentesque purus neque, sollicitudin sit amet mauris id, posuere posuere mi. Etiam vitae urna vitae turpis volutpat consectetur. Quisque ultrices, ex dapibus hendrerit convallis, diam massa suscipit diam, vulputate pharetra mi orci at massa. Aliquam vel urna tempor, congue justo id, pulvinar lorem. Nulla mattis vitae justo sed molestie. Nunc fermentum fringilla nibh, id fermentum nulla. Sed tincidunt ipsum id est efficitur, molestie aliquet lacus hendrerit. Fusce et nisl eros.
- */
-```
-
-
-## Scraping the First Paragraph
-
-La récupération du premier paragraphe du site Web peut être effectuée en accédant au premier élément du tableau (index 0).
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/content/paragraphs.html');
-
-echo $web->paragraphs[0];
-/**
- * Imprime le premier paragraphe:
- *
- * Maecenas eget ex sit amet urna porta fermentum at ut dui. Praesent lectus arcu, hendrerit sed mi vel, commodo lacinia velit. Nullam ac velit quis ante tristique scelerisque quis non metus. Pellentesque non aliquam elit, in tincidunt purus. Vestibulum fringilla cursus risus, eget ornare dolor feugiat vitae. Sed non porta lorem, eget ornare diam. Sed quam est, eleifend porttitor imperdiet sit amet, ultricies vel ipsum. Pellentesque mauris mauris, fermentum pretium ex quis, viverra mattis est. Donec laoreet sem nec arcu rhoncus lobortis. Duis id orci vel enim interdum aliquam. Integer eu ex ligula. Ut mattis nisi non malesuada ornare. In elit ligula, ultricies a aliquet eget, dictum sit amet neque. Quisque nulla sem, aliquam id molestie iaculis, consequat at augue. Nullam sollicitudin finibus eros in venenatis. Donec semper sagittis ipsum, et rhoncus magna ultricies eu.
- */
-```
-
-Des p-tags vides conduiraient à des chaînes vides dans le tableau retourné. Pour éviter cela, vous pouvez appeler `$web->cleanParagraphs` à la place. Cela filtrera les paragraphes vides et ne retournera que ceux qui ont du contenu. Pour accéder au premier paragraphe avec du contenu, utilisez `$web->cleanParagraphs[0]`.
diff --git a/websites/fr/examples/scrape-header-tags.md b/websites/fr/examples/scrape-header-tags.md
deleted file mode 100644
index d3e8e51..0000000
--- a/websites/fr/examples/scrape-header-tags.md
+++ /dev/null
@@ -1,153 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Header%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Gratter les balises d'en-tête
-
-Les balises d'en-tête contiennent souvent des informations utiles sur une page Web et sur la façon dont elle s'intègre dans la structure globale du site dont elle fait partie. Les exemples suivants montrent comment accéder à des éléments d'information particuliers de la balise `
` et à des collections autour de ceux-ci.
-
-
-## Charset
-
-Pour accéder au charset défini, vous pouvez utiliser la méthode suivante:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Imprimez le charset
-echo $web->charset; // "utf-8"
-```
-
-
-## Viewport
-
-Dans certains cas, comme pour la fenêtre d'affichage et les méta-mots-clés, la string représente un tableau et sera fournie comme telle:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Obtenez la fenêtre d'affichage sous forme de tableau. Il doit contenir:
- *
- * [
- * 'width=device-width',
- * 'initial-scale=1',
- * 'shrink-to-fit=no',
- * 'maximum-scale=1',
- * 'user-scalable=no'
- * ],
- */
-var_dump($web->viewport);
-```
-
-Si vous avez besoin d'accéder à la string originale de "viewport", vous pouvez utiliser `viewportString`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Obtenir la fenêtre d'affichage sous forme de chaîne. Imprime:
- *
- * "width=device-width, initial-scale=1, shrink-to-fit=no, maximum-scale=1, user-scalable=no"
- */
-echo $web->viewportString;
-```
-
-
-## URL canonique
-
-L'URL canonique, si elle est donnée, est accessible comme indiqué dans l'exemple ci-dessous:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-// Imprimer l'URL canonique
-echo $web->canonical; // "https://test-pages.phpscraper.de/navigation/2.html"
-```
-
-::: tip Conseil
-Si aucun lien canonique n'est défini, la méthode renvoie `null`.
-:::
-
-
-## Content-Type
-
-Pour accéder au type de contenu, vous pouvez utiliser la fonctionnalité suivante:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Imprimez le contentType
-echo $web->contentType; // "text/html; charset=utf-8"
-```
-
-
-## CSFR Token
-
-La méthode CSFR token suppose que le jeton est stocké dans une balise méta avec le nom "csrf-token". C'est la valeur par défaut pour Laravel. Vous pouvez y accéder en utilisant le code suivant:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Obtenir le csrfToken
-echo $web->csrfToken; // "token"
-```
-
-
-## Balises d'en-tête combinées
-
-Si vous voulez accéder à toutes les méthodes mentionnées ci-dessus, utilisez la méthode `headers`. Elle est définie comme suit:
-
-```php
-/**
- * @return array
- */
-public function headers()
-{
- return [
- 'charset' => $this->charset(),
- 'contentType' => $this->contentType(),
- 'viewport' => $this->viewport(),
- 'canonical' => $this->canonical(),
- 'csrfToken' => $this->csrfToken(),
- ];
-}
-```
-
-Plus d'informations sur l'accès à la [balises méta](/fr/examples/scrape-meta-tags.html).
diff --git a/websites/fr/examples/scrape-images.md b/websites/fr/examples/scrape-images.md
deleted file mode 100644
index 4097b57..0000000
--- a/websites/fr/examples/scrape-images.md
+++ /dev/null
@@ -1,79 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Images&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scraping d'images
-
-Vous vous demandez peut-être comment scraper des photos, des images et d'autres graphiques d'un site Web à l'aide de PHPScraper. Comme pour les autres fonctionnalités, le scraping des images & photos d'un site web suit une approche similaire. Tous les graphiques tels que les images, les photos et les infographies peuvent être scrapés et analysés avec des détails tels que les attributs des balises ou seulement comme une liste d'URL.
-
-
-## Scraping Image URLs
-
-L'exemple suivant analyse une page Web à la recherche d'images et renvoie les URL absolues des images sous forme de tableau.
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Cette page contient deux images:
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * [
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- *
- * @note
- *
- * Double car il s'agit de deux fois la même image:
- * Une fois avec un chemin relatif et une fois avec un chemin absolu.
- * Les chemins relatifs sont résolus en chemins absolus par défaut.
- */
-var_dump($web->images);
-```
-
-::: tip Conseil
-Si aucune image n'est trouvée, le tableau reste vide.
-:::
-
-
-## Scraping d'images avec des détails
-
-Si vous avez besoin de plus de détails, les requêtes suivantes vous permettent d'accéder aux attributs de la balise image:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'absolute path',
- * 'width' => null,
- * 'height' => null,
- * ],
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'relative path',
- * 'width' => null,
- * 'height' => null,
- * ]
- */
-var_dump($web->imagesWithDetails);
-```
-
-::: tip SEO
-Le texte `alt` (avec le caractère [mots-clés du contenu](/fr/examples/extract-keywords.html)) est utilisé par les moteurs de recherche pour les recherches basées sur les images. Veillez à toujours le définir.
-:::
-
-
-## Attributs du scraping: Alt, largeur et hauteur
-
-Les attributs pour `alt`, `width` et `height` sont inclus dans l'ensemble de données détaillées.
-
-Si vous avez besoin de plus de données, vous devrez soit étendre la bibliothèque, soit soumettre un problème pour examen.
diff --git a/websites/fr/examples/scrape-links.md b/websites/fr/examples/scrape-links.md
deleted file mode 100644
index da31322..0000000
--- a/websites/fr/examples/scrape-links.md
+++ /dev/null
@@ -1,120 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Links&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scraping Links
-
-Le scraping de liens fonctionne de manière très similaire ay [scraping d'images](/fr/examples/scrape-images.html). Vous pouvez récupérer une liste d'URL sans aucune information supplémentaire ainsi qu'une liste détaillée contenant `rel`, `target` ainsi que d'autres attributs.
-
-
-## Liste de liens simples
-
-L'exemple suivant analyse une page Web à la recherche de liens et renvoie un tableau d'URL absolues:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient 6 liens vers placekitten.com avec des attributs différents:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/links/target.html');
-
-// Imprimer le nombre de liens.
-echo "Cette page contient " . count($web->links) . " liens.\n\n";
-
-// Boucle à travers les liens
-foreach ($web->links as $link) {
- echo " - " . $link . "\n";
-}
-
-/**
- * Combiné, cela s'imprimera:
- *
- * Cette page contient 6 liens.
- *
- * - https://placekitten.com/408/287
- * - https://placekitten.com/444/333
- * - https://placekitten.com/444/321
- * - https://placekitten.com/408/287
- * - https://placekitten.com/444/333
- * - https://placekitten.com/444/321
- */
-```
-
-Si la page ne doit pas contenir de liens, un tableau vide est renvoyé.
-
-
-## Liens avec les détails
-
-Si vous avez besoin de plus de détails, vous pouvez y accéder de la même manière que pour les images. Voici un exemple pour accéder aux données détaillées du premier lien de la page:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Cette page contient un certain nombre de liens avec des attributs rel différents. Pour gagner de la place, ne retenez que le premier:
- *
- * external kitten
- */
-$web->go('https://test-pages.phpscraper.de/links/rel.html');
-
-// Obtenez le premier lien de la page.
-$firstLink = $web->linksWithDetails[0];
-
-/**
- * $firstLink contient maintenant:
- *
- * [
- * 'url' => 'https://placekitten.com/432/287',
- * 'protocol' => 'https',
- * 'text' => 'external kitten',
- * 'title' => null,
- * 'target' => null,
- * 'rel' => 'nofollow',
- * 'isNofollow' => true,
- * 'isUGC' => false,
- * 'isNoopener' => false,
- * 'isNoreferrer' => false,
- * ]
- */
-```
-
-Si vous avez besoin de plus de données, vous devrez soit étendre la bibliothèque, soit soumettre une question pour examen.
-
-
-## Liens internes et liens externes
-
-PHPScraper permet de retourner seulement des liens internes ou externes. L'exemple suivant démontre les deux:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Naviguer vers la page de test.
-$web->go('https://test-pages.phpscraper.de/links/base-href.html');
-
-// Obtenez la liste des liens internes (dans l'exemple, une image est liée).
-var_dump($web->internalLinks);
-/**
- * [
- * 'https://test-pages.phpscraper.de/assets/cat.jpg'
- * ]
- */
-
-// Obtenir la liste des liens externes
-var_dump($web->externalLinks);
-/**
- * [
- * 'https://placekitten.com/408/287'
- * ]
- */
-```
diff --git a/websites/fr/examples/scrape-meta-tags.md b/websites/fr/examples/scrape-meta-tags.md
deleted file mode 100644
index 857b374..0000000
--- a/websites/fr/examples/scrape-meta-tags.md
+++ /dev/null
@@ -1,114 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Meta%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scraping Meta Tags
-
-L'accès aux méta-informations suit un schéma similaire à celui présenté précédemment. [balises d'en-tête](/fr/examples/scrape-header-tags.html). Vous trouverez ci-dessous une série d'exemples:
-
-
-## Meta Author, Description et Image
-
-L'exemple suivant montre l'extraction de trois attributs:
-
-- l'Auteur Meta,
-- la Meta Description et
-- l'URL de la méta-image
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient:
- *
- *
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Obtenir l'information:
-echo $web->author; // "Lorem ipsum"
-echo $web->description; // "Lorem ipsum dolor etc."
-echo $web->image; // "https://test-pages.phpscraper.de/assets/cat.jpg"
-```
-
-
-## Mots-clés Méta
-
-Le méta-tag "keywords" est naturellement un tableau et sera divisé pour votre convenance:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-// Vide les mots clés dans un tableau
-var_dump($web->keywords); // ['one', 'two', 'three']
-```
-
-Vous pouvez également accéder à la chaîne de mots-clés originale:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-// Imprimez les mots-clés sous forme de chaîne
-echo $web->keywordString; // "one, two, three"
-```
-
-::: tip Conseil
-Il s'agit uniquement des mots-clés figurant dans le métabaliseur "keyword". Vous pouvez également [extract the content keywords](/fr/examples/extract-keywords.html) en utilisant PHPScraper.
-:::
-
-
-## Balises Méta combinées
-
-Si vous souhaitez accéder à toutes les propriétés méta, vous pouvez utiliser la méthode `metaTags`. Elle retourne les méthodes mentionnées ci-dessus sous forme de tableau. Elle est définie comme suit:
-
-```php
-/**
- * obtenir les méta collectés sous forme de tableau
- *
- * @return array
- */
-public function metaTags()
-{
- return [
- 'author' => $this->author(),
- 'image' => $this->image(),
- 'keywords' => $this->keywords(),
- 'description' => $this->description(),
- ];
-}
-```
-
-Dans l'exemple ci-dessus, il serait utilisé comme suit:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/keywords/parse-spaces.html');
-
-var_dump($web->metaTags);
-/**
- * Contient:
- *
- * [
- * 'Lorem ipsum',
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ['one', 'two', 'three'],
- * 'Lorem ipsum dolor etc.',
- * ]
- */
-```
-
-
-## Balises Méta manquantes
-
-Si vous avez besoin d'accéder à une autre méta-propriété, veuillez lire l'article suivant [directives de contribution](/contributing.html) avant d'ouvrir une demande de modification ou de soumettre une [problème sur GitHub](https://github.com/spekulatius/phpscraper/issues).
diff --git a/websites/fr/examples/scrape-social-media-meta-tags.md b/websites/fr/examples/scrape-social-media-meta-tags.md
deleted file mode 100644
index 9d97408..0000000
--- a/websites/fr/examples/scrape-social-media-meta-tags.md
+++ /dev/null
@@ -1,103 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Social%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scraping Social Media Meta Tags
-
-L'extraction des balises de partage des médias sociaux d'un site Web peut être effectuée à l'aide des méthodes suivantes. L'ensemble des résultats exacts dépend des balises fournies. Toutes les balises sont incluses, tant qu'elles sont dans l'espace de nom préfixé (par exemple `twitter:` pour les cartes Twitter).
-
-
-## Données Open-Graph (OG)
-
-Il est possible de récupérer les données des graphiques ouverts:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguer vers la page de test. La page contient:
- *
- *
- *
- *
- *
- *
- *
- *
- *
- * @see https://test-pages.phpscraper.de/og/example.html
- */
-$web->go('https://test-pages.phpscraper.de/og/example.html');
-
-// Doit imprimer 'Lorem Ipsum'.
-echo $web->openGraph['og:title'];
-
-// Doit imprimer "Lorem ipsum dolor etc.".
-echo $web->openGraph['og:description'];
-
-// L'ensemble du jeu:
-$data = $web->openGraph;
-
-/**
- * $data contient maintenant:
- *
- * [
- * 'og:site_name' => 'Lorem ipsum',
- * 'og:type' => 'website',
- * 'og:title' => 'Lorem Ipsum',
- * 'og:description' => 'Lorem ipsum dolor etc.',
- * 'og:url' => 'https://test-pages.phpscraper.de/meta/lorem-ipsum.html',
- * 'og:image' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- */
-```
-
-::: tip Conseil
-Si aucune donnée n'a été trouvée, le tableau sera retourné vide.
-:::
-
-
-## Carte Twitter
-
-L'analyse de la carte Twitter fonctionne de la même manière:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. La page contient la carte Twitter suivante:
- *
- *
- *
- *
- *
- *
- *
- *
- * @see https://test-pages.phpscraper.de/twittercard/example.html
- */
-$web->go('https://test-pages.phpscraper.de/twittercard/example.html');
-
-// Devrait imprimer 'summary_large_image'.
-echo $web->twitterCard['twitter:card'];
-
-// Doit imprimer 'Lorem Ipsum'.
-echo $web->twitterCard['twitter:title'];
-
-// L'ensemble du jeu.
-$data = $web->twitterCard;
-
-/**
- * $data contient maintenant:
- *
- * [
- * 'twitter:card' => 'summary_large_image',
- * 'twitter:title' => 'Lorem Ipsum',
- * 'twitter:description' => 'Lorem ipsum dolor etc.',
- * 'twitter:url' => 'https://test-pages.phpscraper.de/meta/lorem-ipsum.html',
- * 'twitter:image' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- */
-```
-
-De manière similaire à Open Graph, le tableau sera vide si aucune balise Twitter Card n'a été trouvée.
diff --git a/websites/fr/examples/scrape-website-title.md b/websites/fr/examples/scrape-website-title.md
deleted file mode 100644
index 9687916..0000000
--- a/websites/fr/examples/scrape-website-title.md
+++ /dev/null
@@ -1,89 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scrape%20Website%20Title&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Scraper le titre d'un site web
-
-Extraire le titre d'un site Web est simple. Les exemples suivants montrent comment cela fonctionne en utilisant PHPScraper.
-
-
-## Exemple simple
-
-Exemple très simple de la façon de récupérer le titre d'un site web:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Naviguer vers la page de test - celle-ci contient une étiquette de titre "Lorem Ipsum".
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Contient:
- *
- * Lorem Ipsum
- */
-
-// Récupérer le titre. Cela renverra: "Lorem Ipsum"
-var_dump($web->title);
-```
-
-
-### Titre manquant
-
-`null` sera retourné si le titre est manquant:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Naviguez vers la page de test - celle-ci ne contient pas de balise titre.
-$web->go('https://test-pages.phpscraper.de/meta/missing.html');
-
-// Récupérer le titre. Ceci retournera null.
-var_dump($web->title);
-```
-
-Note: C'est le comportement par défaut: Si une balise n'a pas été trouvée parce qu'elle est manquante dans le HTML source, `null` sera retourné. Si un élément itérable est vide (par exemple, pour récupérer des images d'une page sans images), un tableau vide sera retourné.
-
-
-## Caractères spéciaux
-
-Chargement d'un titre de site web avec Umlaute allemand
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguez vers la page de test. Elle contient:
- *
- * A page with plenty of German umlaute everywhere (ä ü ö)
- */
-$web->go('https://test-pages.phpscraper.de/meta/german-umlaute.html');
-
-// Imprimer le titre: "A page with plenty of German umlaute everywhere (ä ü ö)"
-echo $web->title;
-```
-
-Cela devrait fonctionner de manière similaire avec tous les caractères UTF-8.
-
-
-## Entités HTML
-
-Les entités HTML doivent être résolues
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Naviguer vers la page de test. Contient:
- *
- * Cat & Mouse
- */
-$web->go('https://test-pages.phpscraper.de/meta/html-entities.html');
-
-// Imprimer le titre: "Cat & Mouse"
-echo $web->title;
-```
-
-::: tip Conseil
-Les entités et les caractères spéciaux ont été pris en compte dans toute la bibliothèque. Si vous trouvez un endroit où ils ne fonctionnent pas comme prévu, veuillez signaler le problème à l'administrateur. [numéro](https://github.com/spekulatius/PHPScraper/issues).
-:::
diff --git a/websites/fr/misc/show-case.md b/websites/fr/misc/show-case.md
deleted file mode 100644
index 2608ab7..0000000
--- a/websites/fr/misc/show-case.md
+++ /dev/null
@@ -1,7 +0,0 @@
-# Show Case
-
-En plus des [tutoriels](/fr/misc/tutorials.html), ces bibliothèques et paquets utilisent PHPScraper. Vous pouvez consulter le code pour en apprendre davantage sur les cas d'utilisation particuliers.
-
-- [datlechin/flarum-link-preview](https://github.com/datlechin/flarum-link-preview): Aperçu du lien pour les tableaux Flarum.
-
-Si vous souhaitez ajouter votre projet, veuillez soumettre une demande de modification.
\ No newline at end of file
diff --git a/websites/fr/misc/sponsors.md b/websites/fr/misc/sponsors.md
deleted file mode 100644
index 34ad4d0..0000000
--- a/websites/fr/misc/sponsors.md
+++ /dev/null
@@ -1,13 +0,0 @@
-# Sponsors
-
-PHP Scraper es compatible con:
-
-
-
-## Devenir un sponsor
-
-Merci d'être intéressé par le fait de devenir un sponsor de PHP Scraper ! PHP Scraper propose des forfaits de sponsoring personnalisés en fonction de vos besoins. Veuillez [prendre contact](https://peterthaleikis.com/contact) pour en discuter les détails.
-
-## Support commercial
-
-Le support pour les applications commerciales, les licences commerciales, le développement personnalisé, etc. peut être [discuté](https://peterthaleikis.com/contact). Nous serions heureux de soutenir votre projet.
\ No newline at end of file
diff --git a/websites/fr/misc/support.md b/websites/fr/misc/support.md
deleted file mode 100644
index 98fa979..0000000
--- a/websites/fr/misc/support.md
+++ /dev/null
@@ -1,13 +0,0 @@
-# Aide
-
-## Autres exemples
-
-Si vous avez besoin de plus d'exemples, consultez la section [tests](https://github.com/spekulatius/phpscraper/tree/master/tests). Ceux-ci contiennent d'autres exemples de la manière de récupérer des données sur des sites web.
-
-## Bugs et autres problèmes
-
-Si vous remarquez des bugs ou des problèmes de nature similaire, veuillez envoyer un message à l'adresse suivante [problème sur GitHub](https://github.com/spekulatius/PHPScraper/issues). N'oubliez pas d'inclure les informations détaillées permettant de reproduire le problème.
-
-## Support commercial
-
-L'assistance pour les applications commerciales, les licences commerciales, le développement personnalisé, etc. [Parlons-en ensemble](https://peterthaleikis.com/contact).
diff --git a/websites/fr/misc/tutorials.md b/websites/fr/misc/tutorials.md
deleted file mode 100644
index 5e570e9..0000000
--- a/websites/fr/misc/tutorials.md
+++ /dev/null
@@ -1,7 +0,0 @@
-# Tutoriels sur le raclage PHP
-
-Les tutoriels suivants utilisent PHPScraper et peuvent vous aider à en apprendre davantage sur les différentes façons d'utiliser PHPScraper.
-
-*Bientôt disponible*
-
-Veuillez noter que les tutoriels n'ont pas été révisés et peuvent être dépassés.
\ No newline at end of file
diff --git a/websites/misc/show-case.md b/websites/misc/show-case.md
deleted file mode 100644
index 0213a4e..0000000
--- a/websites/misc/show-case.md
+++ /dev/null
@@ -1,7 +0,0 @@
-# Show Case
-
-In addition to the [tutorials](/misc/tutorials.html) these libraries and composer packages also use PHPScraper. You can review the code to learn more about the particular use cases.
-
-- [datlechin/flarum-link-preview](https://github.com/datlechin/flarum-link-preview): Link preview for Flarum Boards.
-
-If you'd like add your project please submit a PR.
\ No newline at end of file
diff --git a/websites/misc/sponsors.md b/websites/misc/sponsors.md
deleted file mode 100644
index 384ca56..0000000
--- a/websites/misc/sponsors.md
+++ /dev/null
@@ -1,13 +0,0 @@
-# Sponsors
-
-PHP Scraper is proudly supported by:
-
-
-
-## Becoming a Sponsor
-
-Thank you for your interesting in becoming a supporter of PHP Scraper! PHP Scraper offers custom sponsorship packages to your needs. Please [reach out](https://peterthaleikis.com/contact) to discuss details.
-
-## Commercial Support
-
-Support for commercial applications, commercial licenses, custom development, and similar can be [discussed](https://peterthaleikis.com/contact). We are happy to support your project.
diff --git a/websites/misc/support.md b/websites/misc/support.md
deleted file mode 100644
index db0cbcd..0000000
--- a/websites/misc/support.md
+++ /dev/null
@@ -1,13 +0,0 @@
-# Support
-
-## More Examples
-
-If you are in need of further examples, check the [tests](https://github.com/spekulatius/phpscraper/tree/master/tests). These contain further examples of how to scrape data from websites.
-
-## Bugs and Other Issues
-
-If you should notice any bugs or issues of similar nature, please raise an [issue on GitHub](https://github.com/spekulatius/PHPScraper/issues). Don't forget to include the detailed information to replicate the issue.
-
-## Commercial Support
-
-Support for Commercial Applications, Commercial Licenses, Custom Development, etc. can be [discussed](https://peterthaleikis.com/contact).
diff --git a/websites/misc/tutorials.md b/websites/misc/tutorials.md
deleted file mode 100644
index 333b93a..0000000
--- a/websites/misc/tutorials.md
+++ /dev/null
@@ -1,7 +0,0 @@
-# PHP Scraping Tutorials
-
-The following tutorials use PHPScraper and could help learning more about various ways to use PHPScraper.
-
-*Coming soon*
-
-Please note the tutorials aren't reviewed and might be outdated.
\ No newline at end of file
diff --git a/websites/netlify.toml b/websites/netlify.toml
deleted file mode 100644
index 8ce5adf..0000000
--- a/websites/netlify.toml
+++ /dev/null
@@ -1,8 +0,0 @@
-# Global settings applied to the whole site.
-# See more info here: https://www.netlify.com/docs/netlify-toml-reference/
-
-#[build]
-# command = "yarn run build"
-
-[build.environment]
- NODE_VERSION = "14"
diff --git a/websites/package.json b/websites/package.json
deleted file mode 100644
index 3e68837..0000000
--- a/websites/package.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "license": "UNLICENSED",
- "scripts": {
- "dev": "export NODE_OPTIONS=--openssl-legacy-provider && vuepress dev",
- "build": "vuepress build"
- },
- "dependencies": {
- "@vuepress/plugin-back-to-top": "^1.5.0",
- "@vuepress/plugin-pwa": "^1.5.0",
- "vuepress": "^1.4.1",
- "vuepress-plugin-canonical": "^1.0.0",
- "vuepress-plugin-minimal-analytics": "^0.1.4",
- "vuepress-plugin-seo": "^0.1.2",
- "vuepress-plugin-sitemap": "^2.3.1",
- "vuepress-plugin-social-share": "^1.0.0",
- "vuepress-plugin-umami": "^0.0.4",
- "vuepress-plugin-web-monetization": "^0.0.1"
- }
-}
diff --git a/websites/vi/README.md b/websites/vi/README.md
deleted file mode 100644
index 3fa4bb8..0000000
--- a/websites/vi/README.md
+++ /dev/null
@@ -1,167 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHPScraper:%20an%20highly%20opinionated%20web-interface&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-PHP Scraper: Thu thập thông tin và cào dữ liệu dễ dàng
-==============================================================
-
-![PHP Scraper: Thu thập thông tin và cào dữ liệu dễ dàng](logo-light.png)
-
-*bởi [Peter Thaleikis](https://peterthaleikis.com)*
-
-PHPScraper là một thư viện cào dành cho PHP, đơn giản. Thư viện này sử dụng vài thư viện PHP làm cho việc lấy dữ liệu trang web dễ dàng hơn.
-
-Các ví dụ kể câu chuyện hay hơn nhiều. Hãy xem!
-
-
-Ý tưởng 💡️
-----------
-
-Việc truy cập và lấy các thông tin cơ bản của trang web rất phức tạp. Wrapper [Goutte](https://github.com/FriendsOfPHP/Goutte) này giúp việc này trở nên dễ dàng hơn. Nó giúp bạn tiết kiệm khỏi XPath và đồng., Cho phép bạn truy cập trực tiếp vào mọi thứ bạn cần. Hình dung lại trang web bằng PHP.
-
-
-Nhà tài trợ 💪️
--------------
-
-Dự án này được tài trợ bởi:
-
-
-
-Muốn tài trợ cho dự án này? [Liên hệ](https://peterthaleikis.com/contact).
-
-
-Một vài ví dụ
--------------
-
-Dưới đây là một số ví dụ về những gì mà thư viện cào web hiện có thể làm:
-
-### Cào thông tin meta:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này có:
- *
- *
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Lấy thông tin:
-echo $web->author; // "Lorem ipsum"
-echo $web->description; // "Lorem ipsum dolor etc."
-echo $web->image; // "https://test-pages.phpscraper.de/assets/cat.jpg"
-```
-
-Gần như mọi thông tin đều có thể lấy được trực tiếp, dưới dạng chuỗi hoặc mảng.
-
-
-### Cào nội dung, như hình ảnh
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này có hai ảnh:
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-var_dump($web->imagesWithDetails);
-/**
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'absolute path',
- * 'width' => null,
- * 'height' => null,
- * ],
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'relative path',
- * 'width' => null,
- * 'height' => null,
- * ]
- */
-```
-
-Một số thông tin *tùy chọn* được trả về dưới dạng một mảng với các chi tiết. Đối với ví dụ này, bạn có thể lấy danh sách hình ảnh bằng `$web->images`. Điều này sẽ làm cho việc tìm kiếm trang web của bạn dễ dàng hơn.
-
-Có thể tìm thấy thêm code ví dụ trong các `examples` và `tests`.
-
-
-Cài đặt
-------------
-
-Sử dụng [Composer](https://getcomposer.org) để cài đặt.
-
-### Cài bằng Composer
-
-```bash
-composer require spekulatius/phpscraper
-```
-
-Sau khi cài xong, thư viện sẽ được thêm vào bởi autoloader của Composer.
-After the installation is completed the package will be picked up by the Composer autoloader. Trong các ứng dụng và framework PHP điển hình như Laravel hoặc Symfony, bạn có thể bắt đầu cào ngay bây giờ. Bây giờ bạn có thể sử dụng bất kỳ ví dụ hoặc ví dụ nào được lưu ý trong thư mục `tests/`.
-
-### Sử dụng trong dự án PHP thuần
-
-Nếu bạn đang làm trong dự án PHP thuần, bạn cần phải include autoloader vào đầu tệp PHP;
-
-```php
-require 'vendor/autoload.php';
-```
-
-Nếu bạn đang sử dụng framework như Laravel, Symfony, Laminas, Phalcon hoặc CakePHP, bạn không cần làm bước này. Autoloader sẽ được đưa vào tự động.
-
-
-Cấu hình
--------------
-
-Các cấu hình sau không bắt buộc. Bên dưới là các tuỳ chọn có sẵn.
-
-### Hỗ trợ proxy
-
-Nếu bạn cần sử dụng proxy, bạn có thể cấu hình proxy bằng `setConfig`:
-
-```php
-$web->setConfig(['proxy' => 'http://user:password@127.0.0.1:3128']);
-```
-
-### Timeout
-
-Nếu bạn cần sử dụng `timeout`, bạn có thể cấu hình timeout bằng `setConfig`:
-
-```php
-$web->setConfig(['timeout' => 15]);
-```
-
-Đặt thời gian chờ thành 0 sẽ vô hiệu hóa nó.
-
-### Tắt SSL
-
-Trong khi không được khuyến nghị, bạn có thể phải tắt kiểm tra SSL. Bạn có thể làm như vậy bằng cách sử dụng:
-
-```php
-$web->setConfig(['disable_ssl' => true]);
-```
-
-Bạn có thể gọi `setConfig` nhiều lần. Nó lưu trữ cấu hình và hợp nhất nó với các cài đặt trước đó. Điều này cần được ghi nhớ trong trường hợp sử dụng không mong muốn khi bỏ thiết lập giá trị.
-
-
-Tìm thấy lỗi và muốn sửa nó? Tuyệt vời!
-----------------------------------
-
-Trước khi bắt đầu, hãy đọc qua [hướng dẫn đóng góp](/vi/contributing.html). Mọi thắc mắc vui lòng liên hệ.
-
-
-Tests: Đảm bảo nó hoạt động!
-----------------------------
-
-Đoạn code này gần như được cover bởi tests từ đầu đến cuối. Đối với điều này, các trang web đơn giản được lưu trữ dưới *https://test-pages.phpscraper.de/*, được tải và phân tích cú pháp bằng cách sử dụng [PHPUnit](https://phpunit.de/). Các bài test này cũng thích hợp làm ví dụ - xem `tests/`!
-
-Điều này đang được nói, có lẽ có những trường hợp cạnh không hoạt động và có thể gây ra sự cố. Nếu bạn tìm thấy một lỗi, vui lòng nêu ra một lỗi trên GitHub.
diff --git a/websites/vi/contributing.md b/websites/vi/contributing.md
deleted file mode 100644
index d92f83b..0000000
--- a/websites/vi/contributing.md
+++ /dev/null
@@ -1,26 +0,0 @@
-# Hướng dẫn đóng góp
-
-Trang này chứa các hướng dẫn để đóng góp cho dự án này. Xin vui lòng
-xem lại các nguyên tắc này trước khi gửi bất kỳ pull request nào.
-
-## Pull Requests
-
-Quá trình kéo yêu cầu khác nhau đối với các tính năng và lỗi mới. Trước khi gửi một
-kéo yêu cầu cho một tính năng mới, trước tiên bạn nên tạo sự cố với
-`[Đề xuất]` trong tiêu đề. Đề xuất cũng nên mô tả tính năng mới
-như các ý tưởng thực hiện. Đề xuất sau đó sẽ được xem xét và được chấp thuận
-hoặc bị từ chối. Khi một đề xuất được chấp thuận, một pull request có thể được tạo
-triển khai tính năng mới. Kéo các yêu cầu không tuân theo nguyên tắc này
-sẽ bị đóng ngay lập tức.
-
-Pull request về lỗi có thể được gửi mà không tạo ra bất kỳ vấn đề đề xuất nào. nếu bạn
-tin rằng bạn biết về giải pháp cho một lỗi đã được gửi trên GitHub,
-xin vui lòng để lại một bình luận chi tiết sửa chữa đề xuất của bạn.
-
-### Yêu cầu tính năng
-
-Dự án này tuân theo các tiêu chuẩn mã hóa PSR-0, PSR-1 và PSR-2.
-
-## Nguyên tắc coding
-
-Dự án này tuân theo các tiêu chuẩn mã hóa PSR-0, PSR-1 và PSR-2.
diff --git a/websites/vi/examples/extract-keywords.md b/websites/vi/examples/extract-keywords.md
deleted file mode 100644
index 5862396..0000000
--- a/websites/vi/examples/extract-keywords.md
+++ /dev/null
@@ -1,121 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Extract%20Keywords&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Trích xuất từ khóa
-
-Đôi khi bạn có thể cần trích xuất các thuật ngữ và cụm từ (keywords) quan trọng trong nội dung này. PHPScraper cho phép bạn trích xuất các từ khóa của trang web một cách trực tiếp. Để làm được nó sử dụng các:
-
-- tiêu đề trang web,
-- thẻ meta,
-- tất cả heading,
-- đoạn văn trên trang,
-- liên kết
-- thuộc tính title của ảnh
-
-Mặc dù các cụm từ khóa này được trích xuất, điều đó không có nghĩa là trang thực sự xếp hạng cho các từ khóa này. Quyết định cuối cùng về việc xếp hạng từ khóa của một trang web là với công cụ tìm kiếm.
-
-Ví dụ sau sẽ trả về danh sách tất cả các từ khóa được trích xuất từ trang web:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Chuyển hướng đến trang test.
-// Nó chứa 3 đoạn văn từ bài viết Wikipedia tiếng Anh cho "lorem ipsum"
-$web->go('https://test-pages.phpscraper.de/content/keywords.html');
-
-// số lượng từ khóa.
-$keywords = $web->contentKeywords;
-echo "Trang này chứa " . count($keywords) . " từ khóa.\n\n";
-
-// lặp các từ khóa
-foreach ($keywords as $keyword) {
- echo " - " . $keyword . "\n";
-}
-
-/**
- * Nó sẽ hiển thị:
- *
- * Trang này chứa 40 từ khóa.
- *
- * [...]
- * - graphic
- * - improper latin
- * - introduced
- * - keyword extraction tests
- * - letraset transfer sheets
- * - lorem ipsum
- * - lorem ipsum php rake library lorem ipsum
- * - lorem ipsum text
- * - make
- * - malorum
- * - microsoft word
- * - mid-1980s
- * - nonsensical
- * - page
- * - paragraphs
- * - philosopher cicero
- * - php rake library
- * - popular word processors including pages
- * - popularized
- * - removed
- * - roman statesman
- * - source
- * [...]
- */
-```
-
-::: tip
-Ngôn ngữ mặc định (locale) là `en_US`. Các ngôn ngữ khác có thể được truyền dưới dạng tham số. Điều này hiện chỉ hoạt động cho một số ngôn ngữ. Xem [danh sách này](https://github.com/Donatello-za/rake-php-plus#currently-supported-languages) để biết thêm chi tiết.
-:::
-
-## Chấm điểm từ khóa
-
-Không phải mọi từ khóa đều có điểm số như nhau trong thuật toán xếp hạng của các công cụ tìm kiếm. Sự kết hợp của một số yếu tố và tín hiệu SEO quyết định trọng lượng mà công cụ tìm kiếm gán cho một từ. Tần suất của từ, độ dài của văn bản và các biến thể như từ đồng nghĩa có thể dẫn đến trọng số khác nhau.
-
-PHPScraper cho phép bạn lấy điểm số của từ khóa:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Điều hướng đến trang test.
-// Nó chứa 3 đoạn văn từ bài viết Wikipedia tiếng Anh cho "lorem ipsum"
-$web->go('https://test-pages.phpscraper.de/content/keywords.html');
-
-// kiểm tra số lượng từ khóa.
-$keywords = $web->contentKeywordsWithScores;
-echo "Trang này chứa " . count($keywords) . " từ khóa.\n\n";
-
-// Loop through the keywords
-foreach ($keywords as $keyword => $score) {
- echo sprintf(" - %s (%s)\n", $keyword, $score);
-}
-
-/**
- * Sẽ in ra:
- *
- * Trang này chứa 40 từ khóa.
- *
- * [...]
- * - 1960s (1.0)
- * - added (1.0)
- * - adopted lorem ipsum (11.0)
- * - advertisements (1.0)
- * - aldus employed (4.0)
- * - corrupted version (4.0)
- * - graphic (1.0)
- * - improper latin (4.0)
- * - introduced (1.0)
- * - keyword extraction tests (9.0)
- * - test (1.0)
- * - microsoft word (5.3333333333333)
- * - english wikipedia (4.0)
- * - lorem ipsum (8.0)
- * - lorem ipsum text (11.0)
- * [...]
- */
-```
-
-::: tip
-Hàm PHP [similar_text](https://www.php.net/manual/en/function.similar-text.php) và [levenshtein](https://www.php.net/manual/en/function.levenshtein.php) có thể giúp bạn xác định và hợp nhất các từ khóa tương tự cũng như các biến thể lỗi đánh máy của từ khóa. [Keyword Merge](https://github.com/spekulatius/keyword-merge) là một thư viện composer để giúp phân loại các từ khóa tương tự.
-:::
diff --git a/websites/vi/examples/headings.md b/websites/vi/examples/headings.md
deleted file mode 100644
index d7c5c31..0000000
--- a/websites/vi/examples/headings.md
+++ /dev/null
@@ -1,120 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Headings&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Thu thập heading
-
-Heading hữu ích trong việc lấy ý tưởng từ nội dung của trang web. Ví dụ sau sẽ cho thấy cách lấy nó:
-
- - Một heading
- - Tất cả heading với cấp cụ thể (e.g. `
`)
- - Tất cả heading trên trang
-
-## Thu thập một heading
-
-Thu thập một heading đơn rất dễ dàng và được thực hiện theo ví dụ sau:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này chứa:
- *
- * Outline Test
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-// Print the H1 heading
-echo $web->h1[0]; // "Outline Test"
-```
-
-::: tip
-[Tiêu đề trang web](/vi/examples/scrape-website-title.html) và heading 1 (`
`) có thể khác nhau. Đảm bảo rằng bạn truy xuất đúng.
-:::
-
-## Heading theo cấp độ
-
-Có thể có những trường hợp, trong đó bạn muốn truy xuất tất cả các heading của một cấp cụ thể. Ví dụ dưới đây cho bạn thấy cách làm như vậy:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này chứa:
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-/**
- * Lấy các heading 3:
- *
- * [
- * 'Example 1',
- * 'Example 2',
- * 'Example 3'
- * ]
- */
-$web->h3;
-```
-
-Nếu không có heading nào, mảng sẽ rỗng:
-
-## Tất cả heading trên trang
-
-Để lấy toàn bộ heading trên trang, bạn có thể truy cập vào cấp độ từ 1 đến 6. Hoặc bằng cách sử dụng:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này có:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- */
-$web->go('https://test-pages.phpscraper.de/content/online.html');
-
-/**
- * bây giờ $headings có:
- *
- * [
- * [
- * 'We are testing here!'
- * ],
- * [
- * 'Examples'
- * ],
- * [
- * 'Example 1',
- * 'Example 2',
- * 'Example 3',
- * ],
- * [],
- * [],
- * []
- * ]
- */
-$web->headings;
-```
-
-Như bạn có thể thấy, phần này không chứa bất kỳ thông tin nào về cấu trúc của các heading. Nó hoàn toàn để biết những heading nào tồn tại. Nếu bạn muốn có một [outline](/vi/examples/outline.html) bạn sẽ cần sử dụng các phương pháp liên quan.
diff --git a/websites/vi/examples/lists.md b/websites/vi/examples/lists.md
deleted file mode 100644
index e8908fd..0000000
--- a/websites/vi/examples/lists.md
+++ /dev/null
@@ -1,70 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Lists&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Thu thập danh sách
-
-Thu thập danh sách tương tự như các kiểu thu thập khác với PHPScraper:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Chuyển hướng đến trang test, trang này chứa:
- *
- *
Example 1: Unordered List
- *
- *
Unordered list item 1
- *
Unordered list item 2
- *
Unordered list item with HTML
- *
- *
- *
Example 2: Ordered List
- *
- *
Ordered list item 1
- *
Ordered list item 2
- *
Ordered list item with HTML
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/lists.html');
-
-/**
- * Chỉ danh sách không có thứ tự (
)
- *
- * [
- * "type" => "ul",
- * "children" => ... // List of childNodes
- * "children_plain" =>
- * [
- * "Unordered list item 1"
- * "Unordered list item 2"
- * "Unordered list item with HTML"
- * ]
- * ]
- */
-var_dump($web->unorderedLists);
-
-/**
- * Chỉ danh sách có thứ tự ()
- *
- * [
- * "type" => "ul",
- * "children" => ... // List of childNodes
- * "children_plain" =>
- * [
- * "Ordered list item 1"
- * "Ordered list item 2"
- * "Ordered list item with HTML"
- * ]
- * ]
- */
-var_dump($web->orderedLists);
-
-
-// Cả hai danh sách kết hợp (như trên)
-var_dump($web->lists);
-```
-
-::: warning Danh sách lồng nhau
-Hiện tại, danh sách lồng nhau không được hỗ trợ. Danh sách lồng nhau được đính kèm với kết quả dưới dạng `children` để xử lý thêm.
-:::
diff --git a/websites/vi/examples/navigation.md b/websites/vi/examples/navigation.md
deleted file mode 100644
index 25b4b2c..0000000
--- a/websites/vi/examples/navigation.md
+++ /dev/null
@@ -1,56 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Navigate%20while%20Scraping&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Điều hướng
-
-Đa số là PHPScraper phân tích và thu thập nội dung trang web, thì bạn có thể sử dụng nó để điều hướng trang web. Các ví dụ bên dưới sẽ cho bạn thấy cách *lướt* quanh trang web.
-
-## Sử dụng URL để điều hướng
-
-Bạn có thể điều hướng bất kỳ URL nào. Các URL này thường được lấy từ [phân tích liên kết](/vi/examples/scrape-links.html).
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Bắt đầu bằng trang test #1.
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-// In tiêu đề để xem chúng ta thực sự ở đúng trang hay không...
-echo $web->h1[0]; // 'Page #1'
-
-// Điều hướng đến trang test số 2 bằng cách sử dụng URL tuyệt đối.
-$web->clickLink('https://test-pages.phpscraper.de/navigation/2.html');
-
-// In tiêu đề để xem chúng ta thực sự ở đúng trang hay không...
-echo $web->h1[0]; // 'Page #2'
-```
-
-## Sử dụng Anchor Texts để điều hướng
-
-Bạn có thể sử dụng anchor text trên trang web để *nhấn* vào liên kết để điều hướng:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Bắt đầu bằng trang test #1.
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-/**
- * Trang này chứa:
- *
- * 2 relative
- */
-
-// In tiêu đề để xem chúng ta thực sự ở đúng trang hay không...
-echo $web->h1[0]; // 'Page #1'
-
-
-// We navigate to the test page #2 using the text it has on the page.
-$web->clickLink('2 relative');
-
-// In tiêu đề để xem chúng ta thực sự ở đúng trang hay không...
-echo $web->h1[0]; // 'Page #2'
-```
-
-Chức năng cơ bản này sẽ cho phép bạn điều hướng các trang web.
\ No newline at end of file
diff --git a/websites/vi/examples/outline.md b/websites/vi/examples/outline.md
deleted file mode 100644
index 279bbd3..0000000
--- a/websites/vi/examples/outline.md
+++ /dev/null
@@ -1,210 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scrape%20Content%20Outline&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Trích xuất outline
-
-Đôi khi bạn có thể chỉ muốn lấy [`đề mục`](/vi/examples/headings.html) để xử lý, ví dụ, số lượng hoặc độ dài của các đề mục có thể không phải lúc nào cũng đủ. Trong một số trường hợp, bạn có thể cần xác định cấu trúc thực tế của nội dung. Đối với những trường hợp sử dụng này, bạn có thể muốn xem xét một trong những phương pháp sau:
-
- - `outline` hoạt động tương tự như phương pháp `đề mục` đã đề cập trước đó. Nó cũng trả về tất cả các đề mục, nhưng nó giữ nguyên cấu trúc của tài liệu gốc và cung cấp các cấp đề mục (ví dụ: `h1`) một mình với đầu ra.
-
- - `outlineWithParagraphs` hoạt động tương tự như `outline`, sự khác biệt là phương thức này cũng bao gồm các đoạn văn.
-
- - `cleanOutlineWithParagraphs` hoạt động tương tự như `outlineWithParagraphs`, sự khác biệt bất kỳ thẻ HTML trống nào sẽ bị xóa.
-
-Các ví dụ sau đây sẽ giúp hiểu rõ hơn về chức năng. Có các phương pháp dành riêng cho [trích xuất từ khóa](/vi/examples/extract-keywords.html).
-
-## Trích xuất Outline
-
-Dàn ý của nội dung cho phép bạn xây dựng một chỉ mục của tài liệu. Ví dụ sau đây tạo một phiên bản đánh dấu xuống của các đề mục trong tài liệu được yêu cầu:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này chứa:
- *
- *
We are testing here!
- * [...]
- *
- *
Examples
- * [...]
- *
- *
Example 1
- * [...]
- *
- *
Example 2
- * [...]
- *
- *
Example 3
- * [...]
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-/**
- * $outline sẽ thành:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ]
- * ]
- */
-$outline = $web->outline;
-```
-
-## Trích xuất Outline với đoạn văn
-
-Phương thức sau hoạt động theo cách tương tự như `outline`, nhưng nó cũng bao gồm bất kỳ đoạn nào như một phần của mảng được trả về:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này chứa:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-$content = $web->outlineWithParagraphs;
-/**
- * bây giờ $content chứa:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "p",
- * "content" => "This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example."
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "p",
- * "content" => "There are numerous examples on the website. Please check them out to get more context on how scraping works."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be an example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be the second example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be another example."
- * ], [
- * "tag" => "p",
- * "content" => ""
- * ]
- * ]
- */
-```
-
-## Trích xuất Outline đã cleanup với đoạn văn
-
-Phương pháp sau hoạt động theo cách tương tự như `outlineWithParagraphs`, nhưng nó không bao gồm bất kỳ tiêu đề hoặc đoạn văn nào trống như một phần của mảng được trả về:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này chứa:
- *
- *
We are testing here!
- *
This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example.
- *
- *
Examples
- *
There are numerous examples on the website. Please check them out to get more context on how scraping works.
- *
- *
Example 1
- *
Here would be an example.
- *
- *
Example 2
- *
Here would be the second example.
- *
- *
Example 3
- *
Here would be another example.
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/content/outline.html');
-
-$content = $web->cleanOutlineWithParagraphs;
-/**
- * bây giờ $content chứa:
- *
- * [
- * [
- * "tag" => "h1",
- * "content" => "We are testing here!"
- * ], [
- * "tag" => "p",
- * "content" => "This page contains an example structure to be parsed. It comes with a number of headings and nested paragraphs as an scrape example."
- * ], [
- * "tag" => "h2",
- * "content" => "Examples"
- * ], [
- * "tag" => "p",
- * "content" => "There are numerous examples on the website. Please check them out to get more context on how scraping works."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 1"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be an example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 2"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be the second example."
- * ], [
- * "tag" => "h3",
- * "content" => "Example 3"
- * ], [
- * "tag" => "p",
- * "content" => "Here would be another example."
- * ]
- * ]
- */
-```
diff --git a/websites/vi/examples/paragraphs.md b/websites/vi/examples/paragraphs.md
deleted file mode 100644
index 6fe878d..0000000
--- a/websites/vi/examples/paragraphs.md
+++ /dev/null
@@ -1,61 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Content&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Thu thập văn bản
-
-Thu thập nội dung và đa số là đoạn văn, có thể dễ dàng thu thập bằng PHPScraper. Có một phương pháp chuyên dụng để truy cập các đoạn văn (`
`) trên một trang web. Các ví dụ bên dưới sẽ cho chúng ta thấy lấy nội dung/văn bản trên trang web.
-
-## Lấy toàn bộ đoạn văn
-
-Ví dụ bên dưới sẽ trả về danh sách đoạn văn (thẻ `
`) trên trang web:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-// Chuyển hướng đến trang test. Nó chứa 6 đoạn văn lorem ipsum
-$web->go('https://test-pages.phpscraper.de/content/paragraphs.html');
-
-// kiểm tra số lượng đoạn văn.
-echo "Trang này có " . count($web->paragraphs) . " đoạn văn.\n\n";
-
-// vòng lặp đoạn văn
-foreach ($web->paragraphs as $paragraph) {
- echo " - " . $paragraph . "\n";
-}
-
-/**
- * Sẽ in:
- *
- * Trang này có 6 đoạn văn.
- *
- * - Maecenas eget ex sit amet urna porta fermentum at ut dui. Praesent lectus arcu, hendrerit sed mi vel, commodo lacinia velit. Nullam ac velit quis ante tristique scelerisque quis non metus. Pellentesque non aliquam elit, in tincidunt purus. Vestibulum fringilla cursus risus, eget ornare dolor feugiat vitae. Sed non porta lorem, eget ornare diam. Sed quam est, eleifend porttitor imperdiet sit amet, ultricies vel ipsum. Pellentesque mauris mauris, fermentum pretium ex quis, viverra mattis est. Donec laoreet sem nec arcu rhoncus lobortis. Duis id orci vel enim interdum aliquam. Integer eu ex ligula. Ut mattis nisi non malesuada ornare. In elit ligula, ultricies a aliquet eget, dictum sit amet neque. Quisque nulla sem, aliquam id molestie iaculis, consequat at augue. Nullam sollicitudin finibus eros in venenatis. Donec semper sagittis ipsum, et rhoncus magna ultricies eu.
-
- * - Quisque sed dolor ut nunc accumsan lacinia. Suspendisse vel eros faucibus massa feugiat tristique. Nullam vitae scelerisque felis, malesuada hendrerit felis. Quisque eleifend mi lorem, vitae elementum dolor bibendum et. Etiam et faucibus augue. Pellentesque viverra sagittis consequat. Nulla a mollis ex. Sed vel nisl mauris. Nulla consequat dui sed pulvinar interdum. Integer vehicula molestie quam non fringilla. Duis auctor sem ut purus fringilla, in lacinia dui finibus. Nulla rhoncus semper velit, eget semper tellus suscipit eget. Vestibulum massa tellus, tristique sit amet dolor et, ullamcorper porta turpis. Vivamus eget magna lacinia, pretium sem sed, gravida libero.
-
- * - Ut at nunc laoreet, vestibulum mauris in, volutpat magna. Aliquam sodales orci finibus porta convallis. Vestibulum sollicitudin felis a sem consequat luctus. Sed laoreet porta quam, non pharetra massa mattis semper. Phasellus aliquet tortor ut felis scelerisque, non dapibus justo tincidunt. Donec eu pulvinar nisi, sit amet elementum massa. Nulla in odio est. In neque ligula, tristique rhoncus orci eu, egestas ullamcorper est. Integer rhoncus vel quam vel placerat. In nec metus pellentesque elit accumsan molestie eu posuere odio. Sed at eros nec turpis vestibulum eleifend vel in erat. Etiam vel metus faucibus, tempus enim nec, elementum arcu. Ut nec blandit risus. Nam sapien nunc, tristique sit amet facilisis non, maximus a nulla. Pellentesque vel posuere libero.
-
- * - Morbi volutpat purus odio, vitae scelerisque diam consectetur sed. Cras turpis leo, hendrerit in tempus et, convallis in nibh. Mauris molestie facilisis odio, ac egestas erat ultrices pellentesque. Donec interdum leo quis ipsum sagittis venenatis. Etiam scelerisque mi at metus ullamcorper, vitae tristique est tincidunt. Vestibulum ut congue urna, eu sagittis quam. Phasellus eget arcu sapien. In hac habitasse platea dictumst. Morbi ultrices, felis in faucibus ornare, libero augue scelerisque urna, et feugiat nisl est ut velit. Phasellus felis quam, egestas a faucibus nec, dictum eget enim. In tempor a lacus id facilisis.
-
- * - Donec bibendum finibus neque quis viverra. Ut ut nulla venenatis, accumsan purus nec, ullamcorper nisi. Nulla bibendum dui sit amet velit venenatis, eget viverra nibh accumsan. Fusce pharetra, sem eu mattis varius, massa leo eleifend lectus, quis tempor elit ipsum sit amet lorem. Fusce viverra dictum tortor non sodales. Phasellus at lectus quis arcu finibus imperdiet sed eleifend nulla. Donec blandit egestas nibh ac euismod. Curabitur ac pretium eros.
-
- * - Duis pharetra magna at dolor scelerisque, nec luctus ex pretium. Suspendisse a ante lectus. Donec vehicula condimentum turpis, in hendrerit dui suscipit non. Nullam a ultricies felis. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Praesent aliquet varius mauris nec pretium. Vivamus convallis tincidunt nisi, eget scelerisque dolor facilisis vitae. Pellentesque purus neque, sollicitudin sit amet mauris id, posuere posuere mi. Etiam vitae urna vitae turpis volutpat consectetur. Quisque ultrices, ex dapibus hendrerit convallis, diam massa suscipit diam, vulputate pharetra mi orci at massa. Aliquam vel urna tempor, congue justo id, pulvinar lorem. Nulla mattis vitae justo sed molestie. Nunc fermentum fringilla nibh, id fermentum nulla. Sed tincidunt ipsum id est efficitur, molestie aliquet lacus hendrerit. Fusce et nisl eros.
- */
-```
-
-## Thu thập một đoạn văn
-
-Thu thập một đoạn văn của trang web có thể thực hiện bằng cách truy cập vào phần tử 0 của mảng.
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/content/paragraphs.html');
-
-echo $web->paragraphs[0];
-/**
- * In đoạn văn đầu tiên:
- *
- * Maecenas eget ex sit amet urna porta fermentum at ut dui. Praesent lectus arcu, hendrerit sed mi vel, commodo lacinia velit. Nullam ac velit quis ante tristique scelerisque quis non metus. Pellentesque non aliquam elit, in tincidunt purus. Vestibulum fringilla cursus risus, eget ornare dolor feugiat vitae. Sed non porta lorem, eget ornare diam. Sed quam est, eleifend porttitor imperdiet sit amet, ultricies vel ipsum. Pellentesque mauris mauris, fermentum pretium ex quis, viverra mattis est. Donec laoreet sem nec arcu rhoncus lobortis. Duis id orci vel enim interdum aliquam. Integer eu ex ligula. Ut mattis nisi non malesuada ornare. In elit ligula, ultricies a aliquet eget, dictum sit amet neque. Quisque nulla sem, aliquam id molestie iaculis, consequat at augue. Nullam sollicitudin finibus eros in venenatis. Donec semper sagittis ipsum, et rhoncus magna ultricies eu.
- */
-```
-Thẻ
rỗng sẽ dẫn đến các chuỗi rỗng trong mảng sẽ được trả về. Để tránh điều này bạn có thể gọi `$web->cleanParagraphs`. Nó sẽ lọc các đoạn văn rỗng và chỉ trả về các đoạn văn có nội dung. Để lấy nội dung đoạn văn đầu tiên chúng ta sử dụng `$web->cleanParagraph[0]`.
diff --git a/websites/vi/examples/scrape-header-tags.md b/websites/vi/examples/scrape-header-tags.md
deleted file mode 100644
index 348337d..0000000
--- a/websites/vi/examples/scrape-header-tags.md
+++ /dev/null
@@ -1,147 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Header%20Tags&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Thu thập thẻ Header
-
-Thẻ header thường chứa các thông tin hữu ích về trang web. Các ví dụ dưới đây sẽ cho thấy cách lấy các thông tin cụ thể từ thẻ `head`.
-
-## Charset
-
-Để lấy `charset` đã khai báo, bạn có thể sử dụng phương thức sau:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này có:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// In charset
-echo $web->charset; // "utf-8"
-```
-
-## Viewport
-
-Trong vài trường hợp, như viewport và các từ khóa meta, chuỗi sẽ được chuêynr thành mảng và được cung cấp như sau:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này có:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Lấy viewport dưới dạng mạng, nó sẽ in:
- *
- * [
- * 'width=device-width',
- * 'initial-scale=1',
- * 'shrink-to-fit=no',
- * 'maximum-scale=1',
- * 'user-scalable=no'
- * ],
- */
-var_dump($web->viewport);
-```
-
-Nếu bạn cần lấy chuỗi gốc của "viewport", bạn có thể sử dụng `viewportString`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * Lấy viewport dưới dạng string, nó sẽ in:
- *
- * "width=device-width, initial-scale=1, shrink-to-fit=no, maximum-scale=1, user-scalable=no"
- */
-echo $web->viewportString;
-```
-
-## Canonical URL
-
-Nếu URL chuẩn được tìm tháy, có thể lấy theo ví dụ bên dưới:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này có:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/navigation/1.html');
-
-// In URL canonical
-echo $web->canonical; // "https://test-pages.phpscraper.de/navigation/2.html"
-```
-
-::: tip
-Nếu không có liên kết chuẩn nào, phương thức sẽ trả về `null`.
-:::
-
-## Content-Type
-
-Bạn có thể lấy kiểu nội dung của trang web bằng cách sử dụng `contentType`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này có:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// In contentType
-echo $web->contentType; // "text/html; charset=utf-8"
-```
-
-## CSFR Token
-
-Đối với Laravel, mã token CSRF thường nằm trong thẻ meta có tên là `csrf-token`. Bạn có thể lấy nó bằng cách sử dụng `csrfToken`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này có:
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-// Lấy csrfToken
-echo $web->csrfToken; // "token"
-```
-
-## Kết hợp các thẻ header lại
-
-Nếu bạn muốn lấy toàn bộ các thẻ header đã nói bên trên bằng phương thức `headers()`. Có thể làm theo như sau:
-
-```php
-/**
- * @return array
- */
-public function headers()
-{
- return [
- 'charset' => $this->charset(),
- 'contentType' => $this->contentType(),
- 'viewport' => $this->viewport(),
- 'canonical' => $this->canonical(),
- 'csrfToken' => $this->csrfToken(),
- ];
-}
-```
-
-Xem thêm thông tin về cách lấy [thẻ meta](/vi/examples/scrape-meta-tags.html).
diff --git a/websites/vi/examples/scrape-images.md b/websites/vi/examples/scrape-images.md
deleted file mode 100644
index 86d006e..0000000
--- a/websites/vi/examples/scrape-images.md
+++ /dev/null
@@ -1,74 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Images&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Thu thập hình ảnh
-
-Bạn có thể tự hỏi làm thế nào để lấy hình ảnh từ một trang web bằng cách sử dụng PHPScraper. Cũng giống các chức năng khác, thu thập hình ảnh từ một trang web theo cách tiếp cận tương tự. Tất cả hình ảnh có thể được lấy và phân tích cú pháp cùng với các chi tiết như thuộc tính thẻ hoặc chỉ dưới dạng danh sách URL.
-
-## Thu thập liên kết hình ảnh
-
-Ví dụ sau đây sẽ trả về các hình ảnh trên trang web dưới dạng mảng URL:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Trang này có 2 ảnh:
- *
- *
- *
- */
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * [
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * ]
- *
- * @note
- *
- * Có hai cái vì hai ảnh giống nhau:
- * Một ảnh đường dẫn tuyệt đối và một ảnh tương đối.
- * Các đường dẫn tương đối sẽ đổi thành đường dẫn tuyệt đối.
- */
-var_dump($web->images);
-```
-
-::: tip
-Nếu không có hình ảnh nào, mảng sẽ bị rỗng.
-:::
-
-## Thu thập hình ảnh với thông tin chi tiết
-
-Nếu bạn muốn lấy thông tin chi tiết về hình ảnh, ví dụ sau sẽ lấy toàn bộ thuộc tính có trong thẻ `img`:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-$web->go('https://test-pages.phpscraper.de/meta/lorem-ipsum.html');
-
-/**
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'absolute path',
- * 'width' => null,
- * 'height' => null,
- * ],
- * [
- * 'url' => 'https://test-pages.phpscraper.de/assets/cat.jpg',
- * 'alt' => 'relative path',
- * 'width' => null,
- * 'height' => null,
- * ]
- */
-var_dump($web->imagesWithDetails);
-```
-
-::: tip SEO
-Thuộc tính `alt` (với [từ khóa trong nội dung](/vi/examples/extract-keywords.html)) được các công cụ tìm kiếm sử dụng cho các tìm kiếm dựa trên hình ảnh.
-:::
-
-## Lấy các thông tin còn thiếu
-
-Nếu bạn muốn lấy thêm các thông tin khác, bạn có thể tạo một pull request hoặc issue trên github về vấn đề này.
diff --git a/websites/vi/examples/scrape-links.md b/websites/vi/examples/scrape-links.md
deleted file mode 100644
index 297674e..0000000
--- a/websites/vi/examples/scrape-links.md
+++ /dev/null
@@ -1,117 +0,0 @@
----
-image: https://api.imageee.com/bold?text=PHP:%20Scraping%20Links&bg_image=https://images.unsplash.com/photo-1542762933-ab3502717ce7
----
-
-# Thu thập liên kết
-
-Thu thập liên kết hoạt động tương tự như [thu thập hình ảnh](/vi/examples/scrape-images.html. Bạn có thể lấy danh sách URL mà không có bất kỳ thông tin bổ sung nào cũng như danh sách chi tiết chứa `rel`, ` target` hay các thuộc tính khác.
-
-## Danh sách liên kết đơn giản
-
-Ví dụ sau phân tích trang web cho các liên kết và trả về một loạt các URL tuyệt đối:
-
-```php
-$web = new \Spekulatius\PHPScraper\PHPScraper;
-
-/**
- * Điều hướng đến trang test. Có 6 liên kết placekitten.com với các thuộc tính khác nhau:
- *
- *