PHP xml_set_element_handler() 関数


❮ 完全な PHP XML リファレンス

定義と用法

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!

❮ 完全な PHP XML リファレンス