初心者でも簡単にPHPでスクレイピングできる方法

初心者でも簡単にPHPでスクレイピングできる方法 PHPの超基礎
初心者でも簡単にPHPでスクレイピングできる方法
zucksadnetwork

スクレイピングをPHPでする方法とは?

スクレイピングとは、Webページから必要な情報を自動的に取得する技術です。PHPはWebアプリケーション開発によく用いられるプログラミング言語であり、スクレイピングにも利用できます。

PHPでスクレイピングする概要

PHPでスクレイピングを行うには、以下の3つのステップを踏みます。

  1. 対象のWebページのURLにアクセスする
  2. HTMLを解析して必要な情報を抽出する
  3. 抽出した情報を保存または活用する

PHPでスクレイピングするスクリプトサンプルその1

以下は、PHPでスクレイピングを行うための基本的なスクリプトです。

PHP

// 対象のWebページのURLを取得する
$url = "https://example.com/";

// HTTPリクエストを送信してHTMLを取得する
$html = file_get_contents($url);

// HTMLを解析して必要な情報を抽出する
$title = $html->find("title")->text();

// 抽出した情報を表示する
echo $title;

このスクリプトは、まず対象のWebページのURLを取得します。次に、HTTPリクエストを送信してHTMLを取得します。最後に、HTMLを解析してタイトル要素のテキストを抽出し、表示します。

PHPでスクレイピングするスクリプトサンプルその2

以下は、PHPでスクレイピングを行うためのもう少し複雑なスクリプトです。

PHP

// 対象のWebページのURLを取得する
$url = "https://example.com/";

// HTTPリクエストを送信してHTMLを取得する
$html = file_get_contents($url);

// HTMLを解析して必要な情報を抽出する
$items = $html->find(".item");

// 抽出した情報をループで処理する
foreach ($items as $item) {
    // 商品名を取得する
    $name = $item->find(".name")->text();

    // 価格を取得する
    $price = $item->find(".price")->text();

    // 情報を表示する
    echo $name . " " . $price . "<br>";
}

このスクリプトは、対象のWebページから商品情報を取得します。まず、HTMLを解析して「.item」クラスの要素をすべて取得します。次に、ループで各要素を処理し、商品名と価格を抽出して表示します。

PHPでスクレイピングするスクリプトサンプルその3

以下は、PHPでスクレイピングを行うためのさらに複雑なスクリプトです。

PHP

// 対象のWebページのURLを取得する
$url = "https://example.com/";

// HTTPリクエストを送信してHTMLを取得する
$html = file_get_contents($url);

// HTMLを解析して必要な情報を抽出する
$items = $html->find(".item");

// 抽出した情報をループで処理する
foreach ($items as $item) {
    // 商品名を取得する
    $name = $item->find(".name")->text();

    // 価格を取得する
    $price = $item->find(".price")->text();

    // 情報をデータベースに保存する
    $db = new PDO("mysql:host=localhost;dbname=mydb", "username", "password");
    $sql = "INSERT INTO items (name, price) VALUES (?, ?)";
    $stmt = $db->prepare($sql);
    $stmt->execute(array($name, $price));
}

このスクリプトは、対象のWebページから商品情報を取得し、データベースに保存します。まず、HTMLを解析して「.item」クラスの要素をすべて取得します。次に、ループで各要素を処理し、商品名と価格を抽出してデータベースに保存します。

PHPでスクレイピングするときの注意点

PHPでスクレイピングを行うときは、以下の点に注意する必要があります。

  • 対象のWebサイトの利用規約を必ず確認する。
  • スクレイピングを行う頻度や量を適切に管理する。
  • スクレイピングによってWebサイトに負荷をかけないようにする。

スクレイピングをPHPでする方法のまとめ

PHPでスクレイピングを行うには、以下の3つのステップを踏みます。

  1. 対象のWebページのURLにアクセスする
  2. HTMLを解析して必要な情報を抽出する
  3. 抽出した情報を保存または活用する

ステップ1: 対象のWebページのURLにアクセスする

まず、対象のWebページのURLを取得します。これは、file_get_contents()関数やcurlライブラリなどを使用して行うことができます。

PHP

// file_get_contents()関数を使用する
$html = file_get_contents("https://example.com/");

// curlライブラリを使用する
$ch = curl_init("https://example.com/");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$html = curl_exec($ch);
curl_close($ch);

ステップ2: HTMLを解析して必要な情報を抽出する

次に、HTMLを解析して必要な情報を抽出します。これは、HTML DOMツリーを処理するライブラリや、XPathやCSSセレクタなどのパーサーを使用して行うことができます。

PHP

// DOMツリーを処理するライブラリを使用する
$html = new DOMDocument();
$html->loadHTML($html_string);

// XPathを使用する
$title = $html->xpath("//title")[0]->textContent;

// CSSセレクタを使用する
$items = $html->querySelectorAll(".item");

ステップ3: 抽出した情報を保存または活用する

最後に、抽出した情報を保存または活用します。これは、ファイルに書き込む、データベースに保存する、またはその他の方法で行うことができます。

PHP

// ファイルに書き込む
file_put_contents("data.txt", $html);

// データベースに保存する
$db = new PDO("mysql:host=localhost;dbname=mydb", "username", "password");
$sql = "INSERT INTO items (name, price) VALUES (?, ?)";
$stmt = $db->prepare($sql);
$stmt->execute(array($name, $price));

// その他の方法で活用する
// 例えば、APIとして公開する

PHPでスクレイピングを行う際には、対象のWebサイトの利用規約を必ず確認し、スクレイピングを行う頻度や量を適切に管理するように注意しましょう。また、スクレイピングによってWebサイトに負荷をかけないようにすることも重要です。

PHPの超基礎
PHPプログラミング図鑑をフォローする
PHPプログラミング図鑑