使用外部XML(CDATA)中的array_unique对数组进行排序



我无法手动对数组进行排序。这是一个包含城市的数组,我从外部XML中获得。

XML看起来像这样,它是我试图排序的节点localidad

<parada>
<id>506</id>
<localidad>
<![CDATA[ Alvor ]]>
</localidad>
<parada>
<![CDATA[ Alvor Baia Hotel (Bus Stop Alvor Férias) ]]>
</parada>
<lat>37.1296</lat>
<lng>-8.58058</lng>
<horasalida>05:40</horasalida>
</parada>

相关代码:

$xml = new SimpleXMLElement($viajes);
foreach ($xml->parada as $excursion) {
$newParadasarray[] = $excursion->localidad;
}
$newParadasarray = array_unique($newParadasarray);
foreach ($newParadasarray as $parada) {
if (strpos($parada, 'Almuñecar') !== false)
echo '<option value="Almuñecar">Almuñecar</option>';
if (strpos($parada, 'Benalmádena') !== false)
echo '<option value="Benalmádena Costa">Benalmádena Costa</option>';
if (strpos($parada, 'Estepona') !== false)
echo '<option value="Estepona">Estepona</option>';
etc.
}

我试过使用sort()array_values()

这是print_r($newParadasarray):的输出

Array (
[0]  => SimpleXMLElement Object ( [0] => SimpleXMLElement Object ( ) )
[1]  => SimpleXMLElement Object ( [0] => SimpleXMLElement Object ( ) )
[2]  => SimpleXMLElement Object ( [0] => SimpleXMLElement Object ( ) )
[4]  => SimpleXMLElement Object ( [0] => SimpleXMLElement Object ( ) )
[9]  => SimpleXMLElement Object ( [0] => SimpleXMLElement Object ( ) )
[14] => SimpleXMLElement Object ( [0] => SimpleXMLElement Object ( ) )
[20] => etc.

问题是,您将SimpleXMLElement分配到数组中,而需要元素的内容,所以只需更改行。。。

$newParadasarray[] = $excursion->localidad;

$newParadasarray[] = trim((string)$excursion->localidad);

强制转换(string)获取文本内容,trim()删除其周围多余的空白

我假设您有多个<parada>元素,因此$xml->parada返回正确的数据。

如果您熟悉DOMDocument,您可以简单地执行以下操作:

$doc = new DOMDocument();
$doc->loadXML($xml);
$array = array();
foreach($doc->getElementsByTagName("localidad") as $localidad) {
$array[] = trim($localidad->nodeValue);
}
$array = array_unique($array);
sort($array);

相关内容

  • 没有找到相关文章

最新更新