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] => George
    )
[2] => Array
  (
  [tag] => NOTE
  [value] =>
  [type] => cdata
  [level] => 1
  )
  [3] => Array
    (
    [tag] => FROM
    [type] => complete
    [level] => 2
    [value] => John
    )
[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 the meeting!
    )
[8] => Array
  (
  [tag] => NOTE
  [value] =>
  [type] => cdata
  [level] => 1
  )
[9] => Array
  (
  [tag] => NOTE
  [type] => close
  [level] => 1
  )
)