PHP xml_set_element_handler() 関数
定義と使用法
xml_set_element_handler() 関数は、開始および終了要素ハンドラを設定します。
ハンドラが成功して作成された場合、この関数は true を返します;それ以外の場合は false を返します。
構文
xml_set_element_handler(parser,start,end)
パラメータ | 説明 |
---|---|
parser | 必須。使用するXML解析器を指定します。 |
start | 必須。要素開始時に呼び出される関数を指定します。 |
end | 必須。要素終了時に呼び出される関数を指定します。 |
由 start パラメータに指定された関数は、以下の3つのパラメータを持たなければなりません:
パラメータ | 説明 |
---|---|
parser | 必須。XML解析器を含む変数を指定します。 |
name | 必須。変数を指定し、その変数が要素の名前を含み、その要素がこの関数をトリガーする。 |
data | 必須。要素属性を含む配列を指定します。 |
由 end パラメータに指定された関数は、以下の3つのパラメータを持たなければなりません:
パラメータ | 説明 |
---|---|
parser | 必須。XML解析器を含む変数を指定します。 |
name | 必須。変数を指定し、その変数が要素の名前を含み、その要素がこの関数をトリガーする。 |
説明
start および end パラメータは配列でもあり、オブジェクトの参照とメソッド名を含むことができます。
例
<?php $parser=xml_parser_create(); function start($parser,$element_name,$element_attrs) { switch($element_name) { case "NOTE": echo "-- 注意 --<br />"; break; case "TO": echo "To: "; break; case "FROM": echo "から: "; break; case "HEADING": echo "見出し: "; break; case "BODY": echo "メッセージ: "; } } 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 エラー: %s 行 %d", xml_error_string(xml_get_error_code($parser)), xml_get_current_line_number($parser))); } xml_parser_free($parser); ?>
出力:
-- 注意 -- まで: George から: John 見出し: リマインダー メッセージ: 会議を忘れないで!