<完全なPHPのXMLリファレンス
定義と使用法
xml_parse_into_struct()関数は、配列にXMLデータを解析します。
この関数は、2列にXMLデータを解析します。
- 値配列 - 解析済みXMLからのデータを含みます
- インデックス配列 - 値配列内の値の位置へのポインタを含みます
この関数は失敗に成功した場合に1、または0を返します。
構文
xml_parse_into_struct(parser,xml,value_arr,index_arr)
パラメーター | 説明 |
---|---|
parser | 必須。 使用するXMLパーサを指定します。 |
xml | 必須。 解析するXMLデータを指定します。 |
value_arr | 必須。 XMLデータのためのターゲット配列を指定します。 |
index_arr | 任意。 インデックスデータのターゲット配列を指定します |
ヒントと注意事項
Note: xml_parse_into_struct()関数は失敗の成功のための1と0を返します。 これはTRUEとFALSEと同じではありません。
例
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
//invalid xml file
$xmlfile = 'test.xml';
$xmlparser = xml_parser_create();
// open a file and read data
$fp = fopen($xmlfile, 'r');
$xmldata = fread($fp, 4096);
xml_parse_into_struct($xmlparser,$xmldata,$values);
xml_parser_free($xmlparser);
print_r($values);
?>
上記のコードの出力は次のようになります。
Array
(
[0] => Array
(
[tag] => NOTE
[type] => open
[level] => 1
[value] =>
)
[1] => Array
(
[tag] => TO
[type] => complete
[level] => 2
[value] => Tove
)
[2] => Array
(
[tag] => NOTE
[value] =>
[type] => cdata
[level] => 1
)
[3] => Array
(
[tag] => FROM
[type] => complete
[level] => 2
[value] => Jani
)
[4] => Array
(
[tag] => NOTE
[value] =>
[type] => cdata
[level] => 1
)
[5] => Array
(
[tag] => HEADING
[type] => complete
[level] => 2
[value] => Reminder
)
[6] => Array
(
[tag] => NOTE
[value] =>
[type] => cdata
[level] => 1
)
[7] => Array
(
[tag] => BODY
[type] => complete
[level] => 2
[value] => Don't forget me this weekend!
)
[8] => Array
(
[tag] => NOTE
[value] =>
[type] => cdata
[level] => 1
)
[9] => Array
(
[tag] => NOTE
[type] => close
[level] => 1
)
)
<完全なPHPのXMLリファレンス