وظيفة PHP xml_parse_into_struct()

التعريف والاستخدام

تقوم وظيفة xml_parse_into_struct() بتحليل بيانات XML إلى مصفوفة.

تقوم الوظيفة هذه بتحليل بيانات XML إلى 2 مصفوفات:

  • مصفوفة Value - تحتوي على البيانات من XML المضمن.
  • مصفوفة Index - تحتوي على إشارات إلى المواقع في مصفوفة Value.

إذا نجح، فإن هذه الوظيفة تعود 1. وإذا فشلت، فإنها تعود 0.

القواعد

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:

<?xml version="1.0" encoding="ISO-8859-1"?>
<note>
<to>George</to>
<from>John</from>
<heading>تذكير</heading>
<body>لا تنسى الاجتماع!</body>
</note>

كود PHP:

<?php
//ملف xml غير صالح
$xmlfile = 'test.xml';
$xmlparser = xml_parser_create();
// فتح الملف وإقراء البيانات
$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] => جورج
    )
[2] => Array
  (
  [tag] => NOTE
  [value] =>
  [type] => cdata
  [level] => 1
  )
  [3] => Array
    (
    [tag] => FROM
    [type] => complete
    [level] => 2
    [value] => جون
    )
[4] => Array
  (
  [tag] => NOTE
  [value] =>
  [type] => cdata
  [level] => 1
  )
  [5] => Array
    (
    [tag] => HEADING
    [type] => complete
    [level] => 2
    [value] => تذكير
    )
[6] => Array
  (
  [tag] => NOTE
  [value] =>
  [type] => cdata
  [level] => 1
  )
  [7] => Array
    (
    [tag] => BODY
    [type] => complete
    [level] => 2
    [value] => لا تنسى الاجتماع!
    )
[8] => Array
  (
  [tag] => NOTE
  [value] =>
  [type] => cdata
  [level] => 1
  )
[9] => Array
  (
  [tag] => NOTE
  [type] => close
  [level] => 1
  )
)