0

我在查询网络服务(雅虎天气)时遇到问题。感谢这个很酷的论坛,我找到了以下提示。然而,我无法找回我的价值。

我正在使用提取 CDATA 部分

$conditionIcon = $weatherXmlObject->xpath("//item/description");
$dom = new DOMDocument();
$dom->loadHTML($conditionIcon); // or you can use loadXML
$xml = simplexml_import_dom($dom);
$imgSrc = (string)$xml->body->img['src'];
echo $imgSrc;

$imgSrc 始终为空。

描述看起来像这样

<description><![CDATA[
<img src="http://l.yimg.com/a/i/us/we/52/28.gif"/><br />
<b>Current Conditions:</b><br />
Mostly Cloudy, 50 F<BR />
<BR /><b>Forecast:</b><BR />
Fri - Partly Cloudy. High: 62 Low: 49<br />
Sat - Partly Cloudy. High: 65 Low: 49<br />
<br />
<a    href="http://us.rd.yahoo.com/dailynews/rss/weather/Sunnyvale__CA/*http://weather.yahoo.com/forecast/USCA1116_f.html">Full Forecast at Yahoo! Weather</a><BR/><BR/>
(provided by <a href="http://www.weather.com" >The Weather Channel</a>)<br/>
]]></description>
4

2 回答 2

1

问题是解析器忽略了 CDATA 块中的所有数据。您必须在另一个 DOMDocument 中加载描述正文。

于 2013-10-04T07:47:09.480 回答
0

好的,我解决了这个问题,但是使用了一个正则表达式(感谢这个问题也被讨论过的页面):

// retrieve link to condition image - in description element
$xml = simplexml_load_string($weather_feed, 'SimpleXMLElement', LIBXML_NOCDATA); 
$description = $xml->channel->item->description;
//preg match regular expression to extract weather icon
$imgpattern = '/src="(.*?)"/i';
preg_match($imgpattern, $description, $matches);
$aExport['img_url'] = $matches[1];

干杯

于 2013-10-04T14:36:50.820 回答