SimpleXMLは、XMLデータを簡単に操作して取得するためのPHP拡張です。
SimpleXMLは、ツリーベースのパーサです。
SimpleXMLは、XML文書の構造やレイアウトを知っていれば、要素の名前、属性、テキストコンテンツを簡単に取得する方法を提供します。
SimpleXMLは、XML文書をデータ構造に変換し、配列やオブジェクトのコレクションのように繰り返し処理することができます。
DOMやExpatパーサと比較しても、SimpleXMLは要素からテキストデータを読み取るコードの行が少なくて済みます。
PHP 5時点で、SimpleXML関数はPHPコアの一部です。この機能を使用するためのインストールは不要です。
PHPのsimplexml_load_string()関数は、文字列からXMLデータを入力するために使用します。
次のような、XMLデータを含む変数があったとします:
$myXMLData =
"<?xml version='1.0' encoding='UTF-8'?>
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>";
次の例は、simplexml_load_string()関数を使用して、文字列からXMLデータを入力する方法を示しています:
<?php
$myXMLData =
"<?xml version='1.0' encoding='UTF-8'?>
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>";
$xml=simplexml_load_string($myXMLData) or die("Error: Cannot create object");
print_r($xml);
?>
例の実行 »
上記のコードの出力は次のようになります:
SimpleXMLElement Object ( [to] => Tove [from] => Jani [heading] => Reminder [body] => Don't forget me this weekend! )
ヒント:libxml機能を使用して、文書をロードするときにXMLエラーをすべて取得し、次に、エラーを繰り返し処理します。
次の例では、壊れたXML文字列をロードしてみます::
<?php
libxml_use_internal_errors(true);
$myXMLData =
"<?xml version='1.0' encoding='UTF-8'?>
<document>
<user>John Doe</wronguser>
<email>john@example.com</wrongemail>
</document>";
$xml = simplexml_load_string($myXMLData);
if ($xml === false) {
echo "Failed loading XML: ";
foreach(libxml_get_errors() as $error) {
echo "<br>", $error->message;
}
} else {
print_r($xml);
}
?>
例の実行 »
上のコードの出力は次のようになります:
Failed loading XML:
Opening and ending tag mismatch: user line 3 and wronguser
Opening and ending tag mismatch: email line 4 and wrongemail
PHPのsimplexml_load_file()関数は、XMLデータをファイルから入力するために使用します。
"note.xml" というXMLファイルがあり、次のようになっているとします:
<?xml version="1.0" encoding="UTF-8"?>
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>
下の例は、simplexml_load_file()関数を使用してファイルからXMLデータを入力する方法を示しています:
<?php
$xml=simplexml_load_file("note.xml") or die("Error: Cannot create object");
print_r($xml);
?>
例の実行 »
上のコードの出力は次のとおりです:
SimpleXMLElement Object ( [to] => Tove [from] => Jani [heading] => Reminder [body] => Don't forget me this weekend! )
チップ: 次の章では、SimpleXMLを使用してXMLファイルからノード値を取得/検索方法を示します!
PHP SimpleXML関数の詳細については、 PHP SimpleXMLリファレンスをご覧ください。