2016-12-30 66 views
0

如何获得每个节点FLOWER的所有属性值ID?使用Xpath选择属性并列出基于NODE值的值

<Files> 
<data id="1"> 
    <Type>Flower</Type> 
</data> 
<data id="2"> 
    <Type>Flower</Type> 
</data> 
<data id="3"> 
    <Type>Flower</Type> 
</data> 
<data id="4"> 
    <Type>Flower</Type> 
</data> 
</Files> 

在MySQL的情况下它会像SELECT id from Files WHERE Type="Flower"

如何做这种情况下我的代码的XPath?

并在选项框内使用SimpleXML列出它。

<select> 
<?php 
foreach ($type as $id) { 
echo '<option value="'.$id.'">'.$id.'</option>'; 
} 
?> 
</select> 

回答

1

要获得所有@id属性值尝试

/Files/data[normalize-space(Type) = 'Flower']/@id 
+0

谢谢选择作为答案,因为它比以前的答案更简单!虽然两者都很好。 –

1
'//data[(./Type/text()="Flower")]/@id' 
+0

Thanks Works!但我明智地得到了一个更简单的Answered语法。 –

1

你的XML是无效的,封闭根元素不匹配,并且Type元素被封闭,type。 XML区分大小写。

Xpath工作使用位置路径和条件位置路径是从当前上下文到元素的分层路径。他们返回一个节点列表。该列表可以使用条件进行过滤。

SimpleXMLElement对象有一个方法xpath()在关联节点的上下文中执行表达式。

$xml = <<<'XML' 
<Files> 
<data id="1"> 
    <type>Flower</type> 
</data> 
<data id="2"> 
    <type>Flower</type> 
</data> 
<data id="3"> 
    <type>Flower</type> 
</data> 
<data id="4"> 
    <type>Flower</type> 
</data> 
</Files> 
XML; 

$files = new SimpleXMLElement($xml); 

$target = new SimpleXMLElement('<select/>'); 
foreach ($files->xpath('data[type = "Flower"]') as $data) { 
echo '.'; 
    $option = $target->addChild('option', $data['id']); 
    $option['value'] = $data['id']; 
} 
echo $target->asXml(); 

你不应该创建你的XML文本。为它使用XML Api。

DOM更加具体和强大。例如,您可以将创建的DOM序列化为HTML。

$source = new DOMDocument(); 
$source->loadXml($xml); 
$xpath = new DOMXpath($source); 
$target = new DOMDocument(); 
$select = $target->appendChild($target->createElement('select')); 

foreach ($xpath->evaluate('/Files/data[type = "Flower"]') as $data) { 
    $option = $select->appendChild($target->createElement('option')); 
    $option->setAttribute('value', $data->getAttribute('id')); 
    $option->appendChild($target->createTextNode($data->getAttribute('id'))); 
} 
echo $target->saveHtml($select); 
0

这是我如何使用答案如果你喜欢,随意使用代码。 谢谢!

<?php 
//I have used 2 given answer as example on how i used it. Feel Free to use the code below 
$type = $_GET['type']; 
if(file_exists("xml/data.xml")) { 
$xml = simplexml_load_file('xml/data.xml') or die("Data Missing"); } 
<!-- Code Example 1 --> 
$ids = $xml->xpath('//data[(./Type/text()="'.$type.'")]/@id'); 
<!-- Code Example 2 --> 
$idx = $xml->xpath('/Files/data[normalize-space(Type) = "'.$type.'"]/@id'); 
?> 
<!-- Example 1 --> 
<select> 
    <?php 
//echo $ids[0]; 
foreach ($ids as $id) { 
echo '<option value="'.$id[0].'">'.$id[0].'</option>'; 
} 
?> 
</select> 
<!-- Example 2 --> 
<select> 
    <?php 
//echo $ids[0]; 
foreach ($idx as $id2) { 
echo '<option value="'.$id2[0].'">'.$id2[0].'</option>'; 
} 
?> 
</select> 
<a href="logout.php">Logout 
</a>