繁体   English   中英

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

[英]Generate XML from dynamic PHP with a foreach loop

我正在尝试创建XML提要,本质上是一堆工作清单。 我现在在数据库中有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>

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

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

foreach ($jobs as $job) {
  $i++;
  $j=$xml->addChild('job')
  ...
$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文档的更多信息。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM