>백엔드 개발 >PHP 튜토리얼 >PHP가 XML 파일을 구문 분석하는 네 가지 방법의 예

PHP가 XML 파일을 구문 분석하는 네 가지 방법의 예

WBOY
WBOY원래의
2016-07-25 08:59:10916검색
  1. $simple = "간단한 메모";
  2. $p = xml_parser_create();
  3. xml_parse_into_struct($p, $simple, $vals, $index);
  4. xml_parser_free($p);
  5. echo "인덱스 배열n";
  6. print_r($index );
  7. echo "nVals arrayn";
  8. print_r($vals);
  9. ?>
复system代码

输출 :

  1. $xml = '

  2. note1extra1
  3. note2
  4. note3extra3
  5. ';

  6. $ p = xml_parser_create();

  7. xml_parse_into_struct($p, $xml, $values, $tags);
  8. xml_parser_free($p);
  9. $result = array();
  10. //아래면遍历方式유 버그隐患
  11. for ($i=0; $i $result[$i] = array();
  12. $result[$i]["note "] = $values[$tags["NOTE"][$i]]["value"];
  13. $result[$i]["extra"] = $values[$tags["EXTRA"][ $i]]["값"];
  14. }
  15. print_r($result);
  16. ?>

复主代码>遍历:

  1. $result = array();
  2. $paraTagIndexes = $tags['PARA '];
  3. $paraCount = count($paraTagIndexes);
  4. for($i = 0; $i < $paraCount; $i = 2) {
  5. $para = array();
  6. //遍历para标签对之间的所有值
  7. for($j = $paraTagIndexes[$i]; $j < $paraTagIndexes[$i 1]; $j ) {
  8. $value = $ 값[$j]['값'];
  9. if(empty($value)) continue;

  10. $tagname = strtolower($values[$j]['tag']);

  11. if(in_array($tagname, array('note','extra'))) {
  12. $para[$tagname] = $value;
  13. }
  14. }
  15. $result[] = $para;
  16. }
  17. ?>
제조대형
其实,平时很少用xml_parse_into_struct函数,所以上面所谓“严谨”的代码保不齐还会有其他情况下的bug 。

xml_set_element_handler

这种方式是为parser는 元素起始, 元素终止的回调函数。 는 xml_set_character_data_handler를 사용하여 구문 분석기를 사용합니다. 这种方式写的代码比较清晰,利于维护。 예문:

  1. $xml = <<

  2. note1extra1
  3. note2
  4. note3extra3
  5. XML;

  6. $result = array();

  7. $index = -1;
  8. $currData;

  9. 함수 문자($parser, $data) {

  10. 전역 $currData;
  11. $currData = $data;
  12. }

  13. function startElement($parser, $name, $attribs) {

  14. 전역 $result , $index;
  15. $name = strtolower($name);
  16. if($name == 'para') {
  17. $index ;
  18. $result[$index] = array();
  19. }
  20. }

  21. function endElement($parser, $name) {

  22. global $result, $index, $currData;
  23. $name = strtolower ($name);
  24. if($name == '참고' || $name == 'extra') {
  25. $result[$index][$name] = $currData;
  26. }
  27. }

  28. $xml_parser = xml_parser_create();

  29. xml_set_character_data_handler($xml_parser, "charactor");
  30. xml_set_element_handler($xml_parser, "startElement", "endElement" );
  31. if (!xml_parse($xml_parser, $xml)) {
  32. echo "xml 구문 분석 시 오류: ";
  33. echo xml_error_string(xml_get_error_code($xml_parser));
  34. }
  35. xml_parser_free($xml_parser);

  36. print_r($result);

  37. ?>

复aze代码

set 핸들러 방식은 코드 라인이 더 많지만 아이디어가 명확하고 가독성이 더 우수하지만 첫 번째 방식에 비해 성능이 약간 느리고 유연성이 강하지 않다는 것을 알 수 있습니다. XML Parser는 PHP4를 지원하며 이전 버전을 사용하는 시스템에 적합합니다. PHP5 환경에서는 다음 방법을 우선적으로 사용하세요.

2,SimpleXML

SimpleXML은 PHP5 이후에 제공되는 간단하고 사용하기 쉬운 XML 도구 세트입니다. XML을 처리하기 편리한 객체로 변환할 수 있고, XML 데이터를 구성하고 생성할 수도 있습니다. 단, 네임스페이스를 포함하는 xml에는 적용되지 않으며, xml은 올바른 형식이어야 합니다. simplexml_import_dom, simplexml_load_file, simplexml_load_string의 세 가지 메소드를 제공합니다. 함수 이름을 보면 직관적으로 함수를 알 수 있습니다. 세 가지 함수 모두 SimpleXMLElement 개체를 반환하며 SimpleXMLElement 작업을 통해 데이터를 읽거나 추가합니다.

  1. $string = <<

  2. login
  3. imdonkey
  4. XML ;

  5. $xml = simplexml_load_string($string);

  6. print_r($xml);
  7. $login = $xml->login;//여기서 반환되는 내용 여전히 똑같습니다 SimpleXMLElement 객체입니다
  8. print_r($login);
  9. $login = (string) $xml->login;//데이터 비교를 할 때 먼저 강제 변환에 주의하세요
  10. print_r($login);
  11. ?>

코드 복사

SimpleXML의 장점은 개발을 하게 되지만, xml 전체를 로드한다는 단점이 있습니다. 메모리를 저장한 후 처리하기 때문에 내용이 많은 xml 문서는 파싱이 불가능할 수 있습니다. 작은 파일을 읽는 중이고 xml에 네임스페이스가 포함되어 있지 않다면 SimpleXML을 선택하는 것이 좋습니다.

3, XMLReader XMLReader는 PHP5 이후의 확장 기능이기도 합니다(5.1 이후에는 기본적으로 설치됨). 이는 커서처럼 문서 흐름에서 이동하며 각 노드에서 중지됩니다. 이는 입력에 대한 빠르고 캐시되지 않은 스트리밍 액세스를 제공하고 스트림이나 문서를 읽을 수 있어 사용자가 여기에서 데이터를 추출하고 애플리케이션에 의미가 없는 레코드를 건너뛸 수 있습니다. 1 2 다음 페이지 마지막 페이지



성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.