我以前从未真正使用过DOM解析器,现在我有一个问题.
我该如何从这个标记中提取URL:
<files>
<file path="http://www.thesite.com/download/eysjkss.zip" title="File Name" />
</files>
Run Code Online (Sandbox Code Playgroud)
Ale*_*min 13
使用simpleXML:
$xml = new SimpleXMLElement($xmlstr);
echo $xml->file['path']."\n";
Run Code Online (Sandbox Code Playgroud)
输出:
http://www.thesite.com/download/eysjkss.zip
Run Code Online (Sandbox Code Playgroud)
Gor*_*don 11
要用DOM做到这一点
$dom = new DOMDocument;
$dom->load( 'file.xml' );
foreach( $dom->getElementsByTagName( 'file' ) as $file ) {
echo $file->getAttribute( 'path' );
}
Run Code Online (Sandbox Code Playgroud)
您也可以使用XPath执行此操作:
$dom = new DOMDocument;
$dom->load( 'file.xml' );
$xPath = new DOMXPath( $dom );
foreach( $xPath->evaluate( '/files/file/@path' ) as $path ) {
echo $path->nodeValue;
}
Run Code Online (Sandbox Code Playgroud)
或者直接作为字符串值:
$dom = new DOMDocument;
$dom->load( 'file.xml' );
$xPath = new DOMXPath( $dom );
echo $xPath->evaluate( 'string(/files/file/@path)' );
Run Code Online (Sandbox Code Playgroud)
您也可以通过手动遍历DOM来获取单个节点
$dom = new DOMDocument;
$dom->preserveWhiteSpace = FALSE;
$dom->load( 'file.xml' );
echo $dom->documentElement->firstChild->getAttribute( 'path' );
Run Code Online (Sandbox Code Playgroud)
标记这个CW,因为这已经多次回答(只是使用不同的元素),包括我,但我懒得找到重复.