PHP xml_parse_into_struct() 函数

定义和用法

xml_parse_into_struct() 函数把 XML 数据解析到数组中。

该函数把 XML 数据解析到 2 个数组中:

  • Value 数组 - 包含来自被解析的 XML 的数据
  • Index 数组 - 包含指向Value 数组中值的位置的指针

如果成功,则该函数返回 1。否则返回 0。

语法

  1. xml_parse_into_struct(parser,xml,value_arr,index_arr)
参数 描述
parser 必需。规定要使用的 XML 解析器。
xml 必需。规定要解析的 XML 数据。
value_arr 必需。规定 XML 数据的目标数组。
index_arr 可选。规定 index 数据的目标数组。

提示和注释

注释:xml_parse_into_struct() 若失败返回 0,成功则返回 1。这和 false 与 true 不同,使用例如 === 运算符时要注意。

例子

XML 文件:

  1. <?xml version="1.0" encoding="ISO-8859-1"?>
  2. <note>
  3. <to>George</to>
  4. <from>John</from>
  5. <heading>Reminder</heading>
  6. <body>Don't forget the meeting!</body>
  7. </note>

PHP 代码:

  1. <?php
  2. //无效 xml 文件
  3. $xmlfile = 'test.xml';
  4. $xmlparser = xml_parser_create();
  5.  
  6. // 打开文件并读取数据
  7. $fp = fopen($xmlfile, 'r');
  8. $xmldata = fread($fp, 4096);
  9.  
  10. xml_parse_into_struct($xmlparser,$xmldata,$values);
  11.  
  12. xml_parser_free($xmlparser);
  13. print_r($values);
  14. ?>

输出:

  1. Array
  2. (
  3. [0] => Array
  4. (
  5. [tag] => NOTE
  6. [type] => open
  7. [level] => 1
  8. [value] =>
  9. )
  10. [1] => Array
  11. (
  12. [tag] => TO
  13. [type] => complete
  14. [level] => 2
  15. [value] => George
  16. )
  17. [2] => Array
  18. (
  19. [tag] => NOTE
  20. [value] =>
  21. [type] => cdata
  22. [level] => 1
  23. )
  24. [3] => Array
  25. (
  26. [tag] => FROM
  27. [type] => complete
  28. [level] => 2
  29. [value] => John
  30. )
  31. [4] => Array
  32. (
  33. [tag] => NOTE
  34. [value] =>
  35. [type] => cdata
  36. [level] => 1
  37. )
  38. [5] => Array
  39. (
  40. [tag] => HEADING
  41. [type] => complete
  42. [level] => 2
  43. [value] => Reminder
  44. )
  45. [6] => Array
  46. (
  47. [tag] => NOTE
  48. [value] =>
  49. [type] => cdata
  50. [level] => 1
  51. )
  52. [7] => Array
  53. (
  54. [tag] => BODY
  55. [type] => complete
  56. [level] => 2
  57. [value] => Don't forget the meeting!
  58. )
  59. [8] => Array
  60. (
  61. [tag] => NOTE
  62. [value] =>
  63. [type] => cdata
  64. [level] => 1
  65. )
  66. [9] => Array
  67. (
  68. [tag] => NOTE
  69. [type] => close
  70. [level] => 1
  71. )
  72. )