<完全なPHPのXMLリファレンス
定義と使用法
xml_parse()関数は、XML文書を解析します。
この関数は、成功した場合にTRUE、失敗した場合にFALSEを返します。
構文
xml_parse(parser,xml,end)
パラメーター | 説明 |
---|---|
parser | 必須。 使用するXMLパーサを指定します。 |
xml | 必須。 解析するXMLデータを指定します。 |
end | 任意。 このパラメータがTRUEの場合、データ"xml"パラメータは、この解析で送信されたデータの最後の部分です。 Note:エンティティのエラーが解析の終了時に報告されています。 そして場合にのみ表示されます"end"パラメータがTRUEであります |
ヒントと注意事項
Tip: XMLパーサーを作成するには、使用xml_parser_create()関数を。
例1
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>
PHPコード
<?php
$parser=xml_parser_create();
function char($parser,$data)
{
echo $data;
}
xml_set_character_data_handler($parser,"char");
$fp=fopen("test.xml","r");
while ($data=fread($fp,4096))
{
xml_parse($parser,$data,feof($fp)) or
die (sprintf("XML Error: %s at line %d",
xml_error_string(xml_get_error_code($parser)),
xml_get_current_line_number($parser)));
}
xml_parser_free($parser);
?>
上記のコードの出力は次のようになります。
Tove Jani Reminder Don't forget me this weekend!
例2
同じXMLファイルを使用したが、別の方法でXMLデータを表示:
<?php
$parser=xml_parser_create();
function start($parser,$element_name,$element_attrs)
{
switch($element_name)
{
case "NOTE":
echo "-- Note --<br />";
break;
case "TO":
echo "To: ";
break;
case "FROM":
echo "From: ";
break;
case "HEADING":
echo "Heading: ";
break;
case "BODY":
echo "Message: ";
}
}
function stop($parser,$element_name)
{
echo "<br />";
}
function char($parser,$data)
{
echo $data;
}
xml_set_element_handler($parser,"start","stop");
xml_set_character_data_handler($parser,"char");
$fp=fopen("test.xml","r");
while ($data=fread($fp,4096))
{
xml_parse($parser,$data,feof($fp)) or
die (sprintf("XML Error: %s at line %d",
xml_error_string(xml_get_error_code($parser)),
xml_get_current_line_number($parser)));
}
xml_parser_free($parser);
?>
上記のコードの出力は次のようになります。
-- Note --
To: Tove
From: Jani
Heading: Reminder
Message: Don't forget me this weekend!
<完全なPHPのXMLリファレンス