xml_set_element_handler() 関数は、XML文書内の開始要素と終了要素で呼び出す関数を指定します。
この関数は、成功した場合はTRUEを、失敗した場合はFALSEを返します。
xml_set_element_handler(parser,start,end)
パラメータ | 説明 |
---|---|
parser | 必須。使用するXMLパーサを指定する |
start | 必須。開始要素で呼び出す関数を指定する |
end | 必須。終了要素で呼び出す関数を指定する |
"start" パラメータで指定する関数には、次の3つのパラメータが必要です:
パラメータ | 説明 |
---|---|
parser | 必須。ハンドラを呼び出すXMLパーサを含む変数を指定する |
name | 必須。文字列としてXMLファイルから、この関数をトリガする要素の名前を含む変数を指定する |
data | 必須。XMLファイルの要素属性を含む配列を文字列として指定する |
"end" パラメータで指定した関数には、次の2つのパラメータが必要です:
パラメータ | 説明 |
---|---|
parser | 必須。ハンドラを呼び出すXMLパーサを含む変数を指定する |
name | 必須。文字列としてXMLファイルから、この関数をトリガする要素の名前を含む変数を指定する |
注: start と end パラメータは、オブジェクトへのリファレンスとメソッド名を格納した配列を指定することもできます。
<?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!