如何使用PHP动态生成XML文件?

我必须在运行时动态生成一个xml文件。请帮助我用PHP动态生成下面的XML文件。

<?xml version="1.0" encoding="UTF-8"?>
<xml>
<track>
<path>song1.mp3</path>
<title>Track 1 - Track Title</title>
</track>
<track>
<path>song2.mp3</path>
<title>Track 2 - Track Title</title>
</track>
<track>
<path>song3.mp3</path>
<title>Track 3 - Track Title</title>
</track>
<track>
<path>song4.mp3</path>
<title>Track 4 - Track Title</title>
</track>
<track>
<path>song5.mp3</path>
<title>Track 5 - Track Title</title>
</track>
<track>
<path>song6.mp3</path>
<title>Track 6 - Track Title</title>
</track>
<track>
<path>song7.mp3</path>
<title>Track 7 - Track Title</title>
</track>
<track>
<path>song8.mp3</path>
<title>Track 8 - Track Title</title>
</track>

474454 次浏览

一种容易被破坏的方法是:

<?php
// Send the headers
header('Content-type: text/xml');
header('Pragma: public');
header('Cache-control: private');
header('Expires: -1');
echo "<?xml version=\"1.0\" encoding=\"utf-8\"?>";


echo '<xml>';


// echo some dynamically generated content here
/*
<track>
<path>song_path</path>
<title>track_number - track_title</title>
</track>
*/


echo '</xml>';


?>

将其保存为.php

看看微小但强壮模板系统。它通常用于HTML模板,但也有一个用于XML文件的扩展。我在创建报告时广泛使用这种方法,其中我可以有一个代码文件和两个模板文件(htm和xml),然后用户可以选择是将报告发送到屏幕还是电子表格。

另一个优点是你不需要从头开始编码xml,在某些情况下,我一直想要导出非常大的复杂电子表格,而不是必须编码所有的导出,所需要的是将现有的电子表格保存在xml中,并在需要数据输出的地方替换为代码标记。这是一种快速有效的工作方式。

我将使用SimpleXMLElement

<?php


$xml = new SimpleXMLElement('<xml/>');


for ($i = 1; $i <= 8; ++$i) {
$track = $xml->addChild('track');
$track->addChild('path', "song$i.mp3");
$track->addChild('title', "Track $i - Track Title");
}


Header('Content-type: text/xml');
print($xml->asXML());


?>

$xml->asXML()也可以将文件名作为参数保存到该文件中

要在PHP中创建一个XMLdocument,您应该实例化一个DOMDocument类,创建子节点并将这些节点附加到文档树的正确分支中。

作为参考,你可以阅读http://it.php.net/manual/en/book.dom.php

现在我们将快速浏览下面的代码。

  • 在第2行创建一个空XML文档 (只需指定XML版本(1.0)和编码(utf8))
  • 现在我们需要填充XML树:
    • 我们必须创建一个xmlnode(第5行)
    • 我们要把它加在正确的位置上。我们正在创建根目录,所以我们直接将它附加到domdocument。
    • 注意创建元素将元素附加到节点并返回插入的节点,我们保存这个引用以将轨道节点附加到根节点(顺便称为xml)。

这些都是基本的,你可以在一行中创建和添加一个节点(例如第13行),你可以用dom api做很多其他的事情。这取决于你。

<?php
/* create a dom document with encoding utf8 */
$domtree = new DOMDocument('1.0', 'UTF-8');


/* create the root element of the xml tree */
$xmlRoot = $domtree->createElement("xml");
/* append it to the document created */
$xmlRoot = $domtree->appendChild($xmlRoot);






/* you should enclose the following lines in a cicle */
$currentTrack = $domtree->createElement("track");
$currentTrack = $xmlRoot->appendChild($currentTrack);
$currentTrack->appendChild($domtree->createElement('path','song1.mp3'));
$currentTrack->appendChild($domtree->createElement('title','title of song1.mp3'));


$currentTrack = $domtree->createElement("track");
$currentTrack = $xmlRoot->appendChild($currentTrack);
$currentTrack->appendChild($domtree->createElement('path','song2.mp3'));
$currentTrack->appendChild($domtree->createElement('title','title of song2.mp3'));


/* get the xml printed */
echo $domtree->saveXML();
?>
< p >编辑: 还有一个提示: 使用xmldocument (dom文档或simplexml文档)而不是打印xml的主要优点是可以用xpath查询

搜索xmltree
$query=mysql_query("select * from tablename")or die(mysql_error());
$xml="<libraray>\n\t\t";
while($data=mysql_fetch_array($query))
{


$xml .="<mail_address>\n\t\t";
$xml .= "<id>".$data['id']."</id>\n\t\t";
$xml .= "<email>".$data['email_address']."</email>\n\t\t";
$xml .= "<verify_code>".$data['verify']."</verify_code>\n\t\t";
$xml .= "<status>".$data['status']."</status>\n\t\t";
$xml.="</mail_address>\n\t";
}
$xml.="</libraray>\n\r";
$xmlobj=new SimpleXMLElement($xml);
$xmlobj->asXML("text.xml");

它很简单,只要连接到你的数据库,它会在你的项目文件夹中创建test.xml文件

使用< >强FluidXML < / >强可以很容易地生成XML。

$tracks = fluidxml('xml');


$tracks->times(8, function ($i) {
$this->add([
'track' => [
'path'  => "song{$i}.mp3",
'title' => "Track {$i} - Track Title"
]
]);


});

https://github.com/servo-php/fluidxml

我看到了DOM和SimpleXML的例子,但没有一个使用XMLWriter的例子。

请记住,从我所做的测试来看,DOM和SimpleXML几乎都比XMLWriter慢了一倍,对于较大的文件,您应该考虑使用后者。

下面是一个完整的工作示例,清晰而简单,符合要求,用XMLWriter编写(我相信它会帮助其他用户):

// array with the key / value pairs of the information to be added (can be an array with the data fetched from db as well)
$songs = [
'song1.mp3' => 'Track 1 - Track Title',
'song2.mp3' => 'Track 2 - Track Title',
'song3.mp3' => 'Track 3 - Track Title',
'song4.mp3' => 'Track 4 - Track Title',
'song5.mp3' => 'Track 5 - Track Title',
'song6.mp3' => 'Track 6 - Track Title',
'song7.mp3' => 'Track 7 - Track Title',
'song8.mp3' => 'Track 8 - Track Title',
];


$xml = new XMLWriter();
$xml->openURI('songs.xml');
$xml->setIndent(true);
$xml->setIndentString('    ');
$xml->startDocument('1.0', 'UTF-8');
$xml->startElement('xml');
foreach($songs as $song => $track){
$xml->startElement('track');
$xml->writeElement('path', $song);
$xml->writeElement('title', $track);
$xml->endElement();
}
$xml->endElement();
$xml->endDocument();
$xml->flush();
unset($xml);

希望这段代码可以帮助你。简单易行的解决方案

$dom = new DOMDocument();
$dom->encoding = 'utf-8';
$dom->xmlVersion = '1.0';
$dom->formatOutput = true;
$xml_file_name = './movies_list.xml'; //You can give your path to save file.
$root = $dom->createElement('Movies');
$movie_node = $dom->createElement('movie');
$attr_movie_id = new DOMAttr('movie_id', '5467');
$movie_node->setAttributeNode($attr_movie_id);
        

$child_node_title = $dom->createElement('Title', 'The Campaign');
$movie_node->appendChild($child_node_title);
        

$child_node_year = $dom->createElement('Year', 2012);
$movie_node->appendChild($child_node_year);
        

$child_node_genre = $dom->createElement('Genre', 'The Campaign');
$movie_node->appendChild($child_node_genre);
        

$child_node_ratings = $dom->createElement('Ratings', 6.2);
$movie_node->appendChild($child_node_ratings);
$root->appendChild($movie_node);
$dom->appendChild($root);
$dom->save($xml_file_name);

有关更多信息,请访问此获取详细信息:https://www.guru99.com/php-and-xml.html