<전체 PHP의 XML 참조
정의 및 사용
xml_parse() 함수는 XML 문서를 구문 분석합니다.
이 함수는 성공시 TRUE, 실패하면 FALSE를 반환합니다.
통사론
xml_parse(parser,xml,end)
매개 변수 | 기술 |
---|---|
parser | 필요합니다. 사용하는 XML 파서를 지정합니다 |
xml | 필요합니다. XML 데이터를 구문 분석을 지정합니다 |
end | 선택 과목. 이 매개 변수가 TRUE 인 경우의 데이터 "xml" 매개 변수는이 구문 분석에 전송 된 데이터의 마지막 조각이다. Note: 엔티티 오류가 구문 분석의 끝에서보고됩니다. 경우에만 표시됩니다 "end" 매개 변수가 TRUE |
팁과주의 사항
Tip: XML 파서를 만들려면 사용 xml_parser_create() 함수를.
예 1
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
$parser=xml_parser_create();
function char($parser,$data)
{
echo $data;
}
xml_set_character_data_handler($parser,"char");
$fp=fopen("test.xml","r");
while ($data=fread($fp,4096))
{
xml_parse($parser,$data,feof($fp)) or
die (sprintf("XML Error: %s at line %d",
xml_error_string(xml_get_error_code($parser)),
xml_get_current_line_number($parser)));
}
xml_parser_free($parser);
?>
코드의 출력은 위의 것입니다 :
Tove Jani Reminder Don't forget me this weekend!
예 2
같은 XML 파일을 사용하지만, 다른 방법으로 XML 데이터를 표시 :
<?php
$parser=xml_parser_create();
function start($parser,$element_name,$element_attrs)
{
switch($element_name)
{
case "NOTE":
echo "-- Note --<br />";
break;
case "TO":
echo "To: ";
break;
case "FROM":
echo "From: ";
break;
case "HEADING":
echo "Heading: ";
break;
case "BODY":
echo "Message: ";
}
}
function stop($parser,$element_name)
{
echo "<br />";
}
function char($parser,$data)
{
echo $data;
}
xml_set_element_handler($parser,"start","stop");
xml_set_character_data_handler($parser,"char");
$fp=fopen("test.xml","r");
while ($data=fread($fp,4096))
{
xml_parse($parser,$data,feof($fp)) or
die (sprintf("XML Error: %s at line %d",
xml_error_string(xml_get_error_code($parser)),
xml_get_current_line_number($parser)));
}
xml_parser_free($parser);
?>
코드의 출력은 위의 것입니다 :
-- Note --
To: Tove
From: Jani
Heading: Reminder
Message: Don't forget me this weekend!
<전체 PHP의 XML 참조