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
見出し: リマインダー
メッセージ: 会議を忘れないで!