相关文章推荐
强悍的牛肉面  ·  Qt 添加 QtNetwork 库文件 - ...·  1 月前    · 
无邪的八宝粥  ·  使用分支和循环创建高级聊天流 - Bot ...·  1 周前    · 
文武双全的大白菜  ·  windows下使用密钥进行ssh连接出现私 ...·  1 年前    · 
含蓄的领带  ·  微博python爬虫,每日百万级数据-阿里云 ...·  1 年前    · 
Code  ›  如何使用Node.js编辑XML文件开发者社区
xml语言 xml解析 const
https://cloud.tencent.com/developer/article/1730345
腹黑的墨镜
1 年前
作者头像
ccf19881030
0 篇文章

如何使用Node.js编辑XML文件

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP
返回腾讯云官网
社区首页 > 专栏 > ccf19881030的博客 > 如何使用Node.js编辑XML文件

如何使用Node.js编辑XML文件

作者头像
ccf19881030
发布 于 2020-10-26 17:35:57
2.2K 0
发布 于 2020-10-26 17:35:57
举报

由于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;
 
推荐文章
强悍的牛肉面  ·  Qt 添加 QtNetwork 库文件 - kaizenly
1 月前
无邪的八宝粥  ·  使用分支和循环创建高级聊天流 - Bot Service | Microsoft Learn
1 周前
文武双全的大白菜  ·  windows下使用密钥进行ssh连接出现私钥文件未保护警告 - 简书
1 年前
含蓄的领带  ·  微博python爬虫,每日百万级数据-阿里云开发者社区
1 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号