我试图使用simple_xml从XML文件中获取数据,到目前为止,我可以获得除图像之外的所有数据。如何调用单个图像名称?
SELECT p.resortsn, MAX(p.resort_country_name) as resort_country_name
BULK COLLECT INTO v_resortsn_tbl
FROM TABLE (o_ski_packages) p
GROUP BY p.resortsn
ORDER BY MAX(p.resort_country_name) ASC;
echo' images-> image">&#39 ;; //这不显示
<?php
$ur="http://services2.jupix.co.uk/api/get_properties.php?clientID=35871cc1b6d9ec6237aaaf94aa0e0836&passphrase=cvYG9f";
$xml = simplexml_load_file($ur);
foreach ($xml->property as $property):
var_dump($property->images->image);
我的代码输出如下图所示。如何显示图像编号1 public 1 =&gt;字符串&#39; http://media2.jupix.co.uk/v3/clients/657/properties/1356/IMG_1356_9_large.jpg&#39; (长度= 77)
答案 0 :(得分:0)
我认为SimpleXMLElement::xpath可以做你想要的事情:
你可以尝试一下:
static
或者您可以遍历所有图像并检查您要查找的名称:
<?php
$ur="http://services2.jupix.co.uk/api/get_properties.php?clientID=35871cc1b6d9ec6237aaaf94aa0e0836&passphrase=cvYG9f";
$xml = simplexml_load_file($ur);
$image = $xml->xpath('//property/images/image[@modified="2014-07-23 14:22:05"]')[1]->__toString();
var_dump($image);
如果你想获得每个/ images部分的第二张图像,那么你可以这样做:
$images = $xml->xpath('//property/images/image');
foreach ($images as $image) {
$url = $image->__toString();
if (false !== strpos($url, "_9_large.jpg")) {
var_dump($url);
}
}
答案 1 :(得分:0)
谢谢Guy我找到了解决问题的方法。 看看这个问题的后面,我似乎没有以正确的方式说出来 我想要的是在该部分内显示图像。 Xpath没有必要但我从中学到了东西。这是我的解决方案,如果你能改进它,我们非常欢迎你。
$url ="http://services2.jupix.co.uk/api/get_properties.php?clientID=35871cc1b6d9ec6237aaaf94aa0e0836&passphrase=cvYG9f";
$xml = simplexml_load_file($url);
foreach ($xml->property as $property):
?>
<li>
<h3> <?php echo $property->addressStreet;?> </h3>
<?php
$imgCount = count($property->images->image);
for ($i=0; $i < $imgCount; $i++) { ?>
<img src="<?php echo $property->images->image[$i];?>">
<?php } ?>
<p><?php echo limit_text($property->fullDescription,30);?></p>
<h4>£ <?php echo $property->price;?> </h4>
</li>
<?php endforeach; ?>