使用foreach循环从动态PHP生成XML

时间:2013-09-16 22:43:41

标签: php xml simplexml

我正在尝试创建一个XML Feed,主要是一堆作业列表。我现在在数据库中有39个工作列表,我正在使用SimpleXML创建XML并且它工作得很好,除了它只输出xml中数据库中的最后一条记录。我确信这是一个简单的解决方案。

查看代码,我希望每个作业都在<job>元素内,并且我希望为每个作业创建一个新的<job>元素。所有这些都包含在一个<source>元素中。这是我的PHP代码,下面是我得到的结果 - 你会看到只返回一行而不是全部39行。

<?php
Header('Content-type: text/xml');
class SimpleXMLExtended extends SimpleXMLElement {
  public function addCData($cdata_text) {
    $node = dom_import_simplexml($this);
    $no   = $node->ownerDocument;
    $node->appendChild($no->createCDATASection($cdata_text));
  }
}


$jobs = $dbjobs->find(array('job_title' => array('$exists' => true), 'job_title' => array('$nin'=> array('',' ', null))));
$jobs = iterator_to_array($jobs);
$xml = new SimpleXMLExtended('<source/>');
$i = 0;
foreach ($jobs as $job) {
  $i++;
  $xml->job = NULL;
  $j = $xml->job;
  $j->referencenumber = NULL;
  $j->referencenumber->addCData($job['id']);
  $j->title = NULL;
  $j->title->addCData($job['job_title']);
  $j->url = NULL;
  $j->url->addCData('http://www.site.com/joblisting.php?jl=' . $job['id']);
  $j->description = NULL;
  $j->description->addCData($job['job_description']);
  $j->company = NULL;
  $j->company->addCData($job['company']);
  $j->city = NULL;
  $j->city->addCData($job['city']);
  $j->state = NULL;
  $j->state->addCData($job['state']);
  $j->postalcode = NULL;
  $j->postalcode->addCData('');
  $j->country = NULL;
  $j->country->addCData('US');
  $j->date = NULL;
  $j->date->addCData(date("Y-m-d", $job['added']->sec));
  $j->site = NULL;
  $j->site->addCData('site.com');
  $j->count = NULL;
  $j->count->addCData($i);
}

print($xml->asXML());
?>

以下是我得到的示例回复:

<source>
  <job>
    <referencenumber>230257</referencenumber>
    <title>Home Phone Representative</title>
    <url>http://www.site.com/joblisting.php?jl=230257</url>
    <description></description>
    <company>Media LLC</company>
    <city>San Jose</city>
    <state>CA</state>
    <postalcode></postalcode>
    <country>US</country>
    <date>2013-09-16</date>
    <site>site.com</site>
    <count>39</count>
  </job>
</source>

正如你可以看到它填充得很好,但我需要所有列表而不是循环中的最后一个。感谢您的帮助。

2 个答案:

答案 0 :(得分:0)

您应该将Childs添加到根目录:

foreach ($jobs as $job) {
  $i++;
  $j=$xml->addChild('job')
  ...

答案 1 :(得分:0)

$xml->job = NULL;

是你的黄牌,因为你取消了最后一张唱片。

并且所有$j->xxxxxx = NULL;都没用。

然后编码为

foreach ($jobs as $job) {
  $i++;
  $j = $xml->addChild('job');
  $j->referencenumber->addCData($job['id']);
  $j->title->addCData($job['job_title']);

 (...)

更好。

了解有关查看SimpleXMLElement::addChild doc。

的更多信息