2013-03-04 90 views
1

我使用API​​来显示结果w.r.t以搜索查询。使用PHP读取XML属性

输出将采用XML形式,我需要解析XML并在浏览器中显示结果。

该文件包含许多属性,我不知道如何提取结果。

这里是我的代码:

<?xml version="1.0" ?> 
<S:Envelope xmlns:S="http://schemas.xmlsoap.org/soap/envelope/"> 
<S:Body> 
<ns3:tourDetailsFullResponse xmlns:ns2="http://example.com/" xmlns:ns3="http://example.com/" xmlns:ns4="http://www.example.com/"> 

<ns4:MarketLocalisedTourData SellingCompanyCode="CODE1" OperatingProductCode="CODE2" MarketVariationCode="CODE3" Duration="8" Currency="USD" CatalogueCode="CODE4" TropicsBrochureCode="CODE5" BrandCode="CODE6" BookableOnline="true"> 

<ns4:TourInfo> 
<ns4:TourName>London to Rome Highlights 2013</ns4:TourName> 
<ns4:Metadata> 
    <ns4:TourCategories> 
     <ns4:TourCategory Name="TourStyles"> 
      <ns4:CategoryValue Name="European Discoveries"/> 
     </ns4:TourCategory> 
    </ns4:TourCategories> 
    <ns4:Brochures> 
     <ns4:Brochure Name="CostSaver 2013" Code="CODE1"/> 
    </ns4:Brochures> 
</ns4:Metadata> 
<ns4:ContinentsVisited> 
    <ns4:Continent Name="Europe" Code="EURO"/> 
</ns4:ContinentsVisited> 
<ns4:CountriesVisited> 
    <ns4:Country Name="France" Continent="EURO" Code="FR"/> 
    <ns4:Country Name="United Kingdom" Continent="EURO" Code="GB"/> 
    <ns4:Country Name="Italy" Continent="EURO" Code="IT"/> 
    <ns4:Country Name="Switzerland" Continent="EURO" Code="CH"/> 
</ns4:CountriesVisited> 
<ns4:LocationsVisited> 
    <ns4:Location Name="Paris" Country="FR"/> 
    <ns4:Location Name="Dover" Country="GB"/> 
    <ns4:Location Name="London" Country="GB"/> 
    <ns4:Location Name="Rome" Country="IT"/> 
    <ns4:Location Name="Calais" Country="FR"/> 
    <ns4:Location Name="Venice" Country="IT"/> 
    <ns4:Location Name="Lucerne" Country="CH"/> 
    <ns4:Location Name="Florence" Country="IT"/> 
</ns4:LocationsVisited> 
<ns4:Description>A lively journey through elegant Paris, gorgeous Lake Lucerne, charming Venice and cultural Florence, bookended by stays in London and legendary Rome. Spend a day at leisure in London and get the best views of Rome from high up in St. Peter’s Basilica before throwing a lucky coin in Trevi Fountain.</ns4:Description> 
<ns4:Assets> 
    <ns4:Image Width="297" Url="http://www.example.com/imageurl" Type="map" Name="route_map" Height="297" Caption="route_map"/> 
    <ns4:Image Width="600" Url="http://www.example.com/imageurl" Type="map" Name="route_map" Height="600" Caption="route_map"/> 
    <ns4:Image Width="531" Url="http://www.example.com/imageurl" Type="photo" Name="primary_image" Height="531" Caption="primary_image"/> 
    <ns4:Image Width="125" Url="http://www.example.com/imageurl" Type="photo" Name="primary_image" Height="125" Caption="primary_image"/> 
</ns4:Assets> 
    ....continues 

现在我想提取大陆参观,访问的国家,走访地点,行程,租入资产价值等等

我试图用简单的XML像下面

$feed = "response1_full.xml"; 

$xml = simplexml_load_file($feed); 

print_r($xml); 

foreach($xml->LocationsVisited[0]->attributes() as $a => $b) { 
    echo $a,'="',$b,"\"\n"; 
} 
also tried 
foreach($xml->TourInfo->LocationsVisited[0]->attributes() as $a => $b) { 
    echo $a,'="',$b,"\"\n"; 
} 

也尝试导致同样的错误

所有其他的可能性

Fatal error: Call to a member function attributes() on a non-object in C:\xampp\htdocs\test\xmlread2.php on line 10

我在这两天以上寻找解决方案。

+0

您寻找的解决方案意味着您了解XML中的命名空间以及[如何使用simplexml访问命名空间元素](http://stackoverflow.com/search?q=how+to+access+namespaced+elements+与+ simplexml的)。所以请环顾四周,看看你的问题是否曾被问过。提问并回答你自己的问题也是可以的。 – hakre 2013-03-05 14:11:11

回答

2

如果你想穿越到孩子们在自己的命名空间,你要告诉的SimpleXMLElement其命名空间:

$ns4 = $xml->children('S', true)->Body 
     ->children('ns3', true)->tourDetailsFullResponse 
      ->children('ns4', true); 

$locations = $ns4->MarketLocalisedTourData->TourInfo->LocationsVisited->Location; 

foreach ($locations as $location) { 
    $attributes = $location->attributes(); 
    echo $attributes['Name']; 
    echo $attributes['Country']; 
} 

但是你可以通过使用xpath with the namespace(s) you're interested in by registering them您的生活更轻松。

+0

我试过你的suggesstion,导致'Warning:提供的foreach()在第10行的C:\ xampp \ htdocs \ test \ xmlread2.php中存在无效参数' – vijay 2013-03-04 08:54:06

+0

对不起,我忘记了包含TourInfo – m4t1t0 2013-03-04 09:00:39

+0

其实我也试过,但结果没有变化。 获取相同的错误。 – vijay 2013-03-04 09:16:06

1

$ xml有什么?你能打印结果吗? 如果它不包含任何东西

那么问题是命名空间 看看他以下问题: Remove namespace from XML using PHP

$feed = "response1_full.xml"; 
echo "<pre>"; 
$sxe = simplexml_load_file($feed); 
if ($sxe === false) { 
echo "Failed loading XML\n"; 
foreach(libxml_get_errors() as $error) { 
    echo "\t", $error->message; 
} 
} 
if (file_exists('response1_full.xml')) { 
$xml = simplexml_load_file('response1_full.xml'); 
//print_r($xml); 
} else { 
exit('Failed to open test.xml.'); 
} 
print_r($sxe->Body->tourDetailsFullResponse->MarketLocalisedTourData->TourInfo->LocationsVisited->Location[0]); 
print_r($sxe->Body->tourDetailsFullResponse->MarketLocalisedTourData->TourInfo->LocationsVisited->Location[1]); 
+0

如果我打印$ xml,我会得到以下回答: 'SimpleXMLElement Object()' 而且我已经将该文件保存在该名称下,为什么要将该文件作为字符串加载并再次保存XML!对不起,我不明白.. – vijay 2013-03-04 08:51:56

+0

问题是你的命名空间从标签中删除命名空间和相应的namespce,看看你是否得到任何输出 – 2013-03-04 09:11:35

+0

当我删除名称空间,并试图评估它的对象时,你的问题是与命名空间 – 2013-03-04 11:08:24

1

最后我设法找到通过DOM答案。

@Deepak Srinivasan:我试过你的建议,在执行前注册命名空间,但我没有克服它,可能我不知道如何继续。

@ m4t1t0:谢谢你的回应。

我已粘贴完整文件的pastebin url,您可以从答案下方指定的URL中看到该文件。

我使用getAttribute方法

$doc = new DOMDocument(); 
$doc->load('response1_full.xml'); 

//tourname 
$tname = $doc->getElementsByTagName("TourName"); 
$tourname = $tname->item(0)->nodeValue; 
echo $tourname; 
//locations visited 
$locations = $doc->getElementsByTagName("Location"); 
foreach($locations as $location) 
{ 

    $locationname = $location->getAttribute('Name'); 
    $locationcountry = $location->getAttribute('Country'); 

    echo $locationname.'-'.$locationcountry.'<br>'; 
} 

这正是打印出所需的详细信息的解决方案。

但现在我在同一个文件中有一个小小的疑问, 我有一些嵌套格式的信息,有没有反正我可以很容易地将它拉出来。

这是我对于 http://pastebin.com/iWQf6j4K

Insde的文件,你可以看到一个部分

<ns4:WhatsIncluded> 

其中有标题和文本文件(UL - 李格式)

有什么办法我可以把这个区域内的数据拉出来。 如果我从文本拉动下数据我得到的项目完全是一个段落,

但是当我使用的foreach内文本我只得到了第一项目,

我也尝试过foreach for Textul,但仍然只有一个结果。

任何建议..

非常感谢。