由于XML仍然继续用作数据交换格式(主要是在企业应用程序中),因此了解如何以编程方式操纵XML文件的内容可能非常有用。 您可以轻松地在Node.js中编写一个小的脚本来立即进行更改,而不必手动编辑数百行XML。
在之前的文章中,我们研究了如何通过使用开源xml2js
模块将XML文件转换为Node.js中的JSON对象。 今天,您将学习如何使用Node.js编辑XML文件。
基本设置
首先,通过在终端中键入以下命令,将xml2js
模块添加到您的Node.js应用程序中:
$ node install xml2js --save
接下来,创建一个名为index.js
的新JavaScript文件,其内容如下:
const fs = require("fs");
// read XML file
fs.readFile("databases.xml", "utf-8", (err, data) => {
if (err) {
throw err;
}
console.log(data);
});
上面的代码从磁盘读取XML文件并将其打印在控制台上。 这是一个需要更新的XML文件的示例:
databases.xml
<?xml version="1.0" encoding="UTF-8" ?>
<databases>
<database>
<name>MySQL</name>
<type>RDBMS</type>
</database>
<database>
<name>MongoDB</name>
<type>NoSQL</type>
</database>
<database>
<name>Neo4j</name>
<type>Graph DB</type>
</database>
</databases>
将XML转换成JSON
由于我们现在能够将XML文件读取为字符串,因此可以使用xml2js.parseString()
方法轻松地将其转换为JSON对象。
让我们更新上面的示例代码,以将XML解析包括到JSON:
const fs = require("fs");
const xml2js = require('xml2js');
// read XML file
fs.readFile("databases.xml", "utf-8", (err, data) => {
if (err) {
throw err;
}
// convert XML data to JSON object
xml2js.parseString(data, (err, result) => {
if (err) {
throw err;
}
// print JSON object
console.log(JSON.stringify(result, null, 4));
});
});
如果运行上面的代码,则应该在控制台上看到打印出以下JSON对象:
{
"databases": {
"database": [
{
"name": [
"MySQL"
],
"type": [
"RDBMS"
]
},
{
"name": [
"MongoDB"
],
"type": [
"NoSQL"
]
},
{
"name": [
"Neo4j"
],
"type": [
"Graph DB"
]
}
]
}
}
编辑XML
用JavaScript编辑JSON对象非常简单。 让我们用另一个称为ArangoDB
的图形数据库替换Neo4j
数据库:
// replace `Neo4j` with `ArangoDB`
result.databases.database[2].name = 'ArangoDB';
您还可以将新数据库添加到现有数据库列表中:
// add a new database to list
const postgres = {
name: 'PostgreSQL',
type: 'RDBMS'
};
result.databases.database.push(postgres);
经过以上修改,我们更新后的示例代码如下所示:
const fs = require("fs");
const xml2js = require('xml2js');
// read XML file
fs.readFile("databases.xml", "utf-8", (err, data) => {
if (err) {
throw err;
}
// convert XML data to JSON object
xml2js.parseString(data, (err, result) => {
if (err) {
throw err;
}
// replace `Neo4j` with `ArangoDB`
result.databases.database[2].name = 'ArangoDB';
// add a new database to list
const postgres = {
name: 'PostgreSQL',
type: 'RDBMS'
};
result.databases.database.push(postgres);
// print JSON object
console.log(JSON.stringify(result, null, 4));
});
});
将JSON转换成XML
现在,我们已经成功修改了JSON对象,我们可以将其转换回XML字符串,最后将其写入文件:
const fs = require("fs");
const xml2js = require('xml2js');
// read XML file
fs.readFile("databases.xml", "utf-8", (err, data) => {
if (err) {
throw err;
}
// convert XML data to JSON object
xml2js.parseString(data, (err, result) => {
if (err) {
throw err;
}
// replace `Neo4j` with `ArangoDB`
result.databases.database[2].name = 'ArangoDB';
// add a new database to list
const postgres = {
name: 'PostgreSQL',
type: 'RDBMS'
};
result.databases.database.push(postgres);
// convert JSON objec to XML
const builder = new xml2js.Builder();
const xml = builder.buildObject(result);
// write updated XML string to a file
fs.writeFile('new-databases.xml', xml, (err) => {
if (err) {
throw err;
}
console.log(`Updated XML is written to a new file.`);
});
});
});
仅此而已。 运行上面的代码,您应该在与Node.js脚本文件相同的目录中看到一个由更新的XML生成的新XML文件。
阅读下一篇:如何在Node.js中将XML转换为JSON
喜欢这篇文章吗? 在Twitter和LinkedIn上关注我。 您也可以订阅RSS Feed。
网友评论