<完全なPHPのXMLリファレンス
定義と使用法
xml_set_character_data_handler()関数は、XMLパーサーの文字データハンドラを設定します。
この関数は、パーサーは、XMLファイル内の文字データを見つけたときに呼び出される関数を指定するもの。
この関数は、成功した場合にTRUE、失敗した場合にFALSEを返します。
構文
xml_set_character_data_handler(parser,handler)
パラメーター | 説明 |
---|---|
parser | 必須。 使用するXMLパーサを指定します。 |
handler | 必須。 イベントハンドラとして使用される関数を指定します |
で指定された機能"handler"パラメータは、2つのパラメータを持っている必要があります。
パラメーター | 説明 |
---|---|
parser | 必須。 ハンドラを呼び出すXMLパーサーを含む変数を指定します。 |
data | 必須。 文字列としてXMLファイルから文字データを含む変数を指定します。 |
ヒントと注意事項
Note:ハンドラ・パラメータは、オブジェクト参照とメソッド名を含む配列であることができます。
例
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!
<完全なPHPのXMLリファレンス