echo simplexml对象

时间:2012-06-12 23:44:55

标签: php html rss simplexml blogger

这个问题分为两部分。

第1部分。昨天我有一些代码可以从RSS提要中回显XML的全部内容。然后我从我的php文档中删除它,保存在它上面,我完全在踢自己。

我相信语法是这样的:

$xml = simplexml_load_file($url);
echo $xml;

我再次尝试了它并且它不起作用,所以显然我忘记了正确的语法并且可以使用你的帮助,亲爱的stackoverflow问题回答者。

我一直想弄清楚我在做什么,我无法在Google或PHP网站上找到一个例子。我试过print_r($ url);命令,它给了我一个似乎是源的雾化版本。我想要整个弦乐,疣和所有。我意识到我可以在窗口中输入RSS链接并查看它,但是在编码和编码时将它放在我的PHP页面上会很有帮助。

第2部分我想重建这个的主要原因是因为我试图从博客RSS解析节点,以便在私有域上托管的网页上显示它。我发布了一个虚拟博客,当我没有为其中一个虚拟帖子添加标题时发现了一个尴尬的格式化故障。

那么在这种情况下会怎么做?我试了一下:

if(entry->title == "")
{$entryTitle = "untitled";}

这根本不起作用。

这是我处理博客的整个PHP脚本:

<?php
/*create variables*/
$subtitle ="";
$entryTitle="";
$html = "";
$pubDate ="";
/*Store RSS feed address in new variable*/
$url = "http://www.blogger.com/feeds/6552111825067891333/posts/default";
/*Retrieve BLOG XML and store it in PHP object*/
$xml = simplexml_load_file($url);
print_r($xml);
/*Parse blog subtitle into HTML and echo it on the page*/
$subtitle .= "<h2 class='blog'>" . $xml->subtitle . "</h2><br />";
echo $subtitle;
/*Go through all the entries and parse them into HTML*/
foreach($xml->entry as $entry){
/*retrieve publication date*/
    $xmlDate = $entry->published;
    /*Convert XML timestamp into PHP timestamp*/
    $phpDate = new DateTime(substr($xmlDate,0,19));
    /*Format PHP timestamp to something humans understand*/
    $pubDate .= $phpDate->format('l\, F j\, Y h:i A');
    if ($entry->title == "")
    {
        $entryTitle .= "Untitled";
    }
        echo $entry->title;
    /*Pick through each entry and parse each XML tree node into an HTML ready blog post*/
        $html .= "<h3 class='blog'>".$entry->title . "<span class='pubDate'> | " .$pubDate . "</span></h3><p class='blog'>" . $entry->content . "</p>";
    /*Print the HTML to the web page*/  
        echo $html;
    /*Set the variables back to empty strings so they do not repeat data upon reiteration*/
        $html = "";
        $pubDate = "";
}
?>

4 个答案:

答案 0 :(得分:7)

根据php手册:

$xml = new SimpleXMLElement($string);
.
.
.

然后如果你想echo结果:

echo $xml->asXML();

或将xml保存到文件中:

$xml->asXML('blog.xml'); 

<强>参考

答案 1 :(得分:1)

simplexml_load_file会返回 SimpleXMLElement ,所以:

print_r($xml);

将显示其次要对象数组

调整完成后,您可以拨打 $ xml-&gt; asXML(“filename.xml”); ,如@Tim Withers所指出的那样。

答案 2 :(得分:1)

第1部分

这仍然不是我想要的,而是一种非常整洁有序的回显xml数据的方式:

    $url = "http://www.blogger.com/feeds/6552111825067891333/posts/default";
$xml = simplexml_load_file($url);
echo '<pre>';
print_r($xml);

第2部分

我必须运行firephp所以我可以确切地看到php遇到没有博客标题的条目时遇到的元素。最终它是一个空阵列。因此,简单:

if(empty($entry->title))

完美无缺。对于字符串比较,我发现您可以简单地将其转换为字符串。就我的目的而言,这是不必要的。

答案 3 :(得分:0)

第1部分:echo $xml->asXML(); - http://www.php.net/manual/en/simplexmlelement.asxml.php

第2部分:php SimpleXML check if a child exists

$html .= "<h3 class='blog'>".($entry->title!=null?$entry->title:'No Title')
    . "<span class='pubDate'> | " .$pubDate . "</span></h3><p class='blog'>" 
    . $entry->content . "</p>";

注意我可能会加载这样的网址:

$feedUrl = 'http://www.blogger.com/feeds/6552111825067891333/posts/default';
$rawFeed = file_get_contents($feedUrl);
$xml = new SimpleXmlElement($rawFeed);

根据您对第1部分的评论,我不确定XML是否完全加载。如果您尝试以这种方式加载它,它应该显示所有XML数据。