0

我正在尝试将 xml 解析为 json 并且我在 nodejs 中使用 xml2js。下面是我的代码

var chai = require('chai');
var chaiHttp = require('chai-http');
var request = chai.request;
var should = chai.should();
var expect = chai.expect;
var assert = chai.assert;
var supertest = require('supertest');
var fs = require('fs');
var xmlLocation = "./configdata/xmlDoc.xml";

var xml2js = require('xml2js');
var parser = new xml2js.Parser();

//Plugin for HTTP, etc.
chai.use(chaiHttp);
process.env['NODE_TLS_REJECT_UNAUTHORIZED'] = '0';

//xmlFile = JSON.parse(fs.readFileSync(xmlData, 'utf8'));


describe("Test : ", function () {

    it("convert xml to json", function (done) {

        r = fs.readFileSync(xmlLocation, 'UTF-8');
        parser.parseString(r, function (err, parsedData) {
            if (err) throw err;
            else {
                fs.writeFile("jsonData.json", JSON.stringify(parsedData), function (err, response) {
                });
            }
        });

        done();
    });

})

我的示例 xml 文件:

<?xml version="1.0" encoding="UTF-8" ?>
<ALEXA>
    <SD TITLE="A" FLAGS="" HOST="davidwalsh.name">
        <TITLE TEXT="David Walsh Blog :: PHP, MySQL, CSS, Javascript, MooTools, and Everything Else"/>
        <LINKSIN NUM="1102"/>
        <SPEED TEXT="1421" PCT="51"/>
    </SD>
    <SD>
        <POPULARITY URL="davidwalsh.name/" TEXT="7131"/>
        <REACH RANK="5952"/>
        <RANK DELTA="-1648"/>
    </SD>
</ALEXA>

我得到以下输出:

{
  "ALEXA": {
    "SD": [
      {
        "$": {
          "TITLE": "A",
          "FLAGS": "",
          "HOST": "davidwalsh.name"
        },
        "TITLE": [
          {
            "$": {
              "TEXT": "David Walsh Blog :: PHP, MySQL, CSS, Javascript, MooTools, and Everything Else"
            }
          }
        ],
        "LINKSIN": [
          {
            "$": {
              "NUM": "1102"
            }
          }
        ],
        "SPEED": [
          {
            "$": {
              "TEXT": "1421",
              "PCT": "51"
            }
          }
        ]
      },
      {
        "POPULARITY": [
          {
            "$": {
              "URL": "davidwalsh.name/",
              "TEXT": "7131"
            }
          }
        ],
        "REACH": [
          {
            "$": {
              "RANK": "5952"
            }
          }
        ],
        "RANK": [
          {
            "$": {
              "DELTA": "-1648"
            }
          }
        ]
      }
    ]
  }
}

'$' 被添加到解析的 json 中。如何避免它..??

寻找解决方案。提前致谢。

4

3 回答 3

0

像这样的库通常会解析所有内容,有时会导致许多您不需要的属性。

我为此目的创建了camaro 。

这样做的缺点是您必须为要转换 xml 的结构编写自己的模板文件。

const transform = require('camaro')
const fs = require('fs')

const xml = fs.readFileSync('ean.xml', 'utf-8')
const template = {
    cache_key: "/HotelListResponse/cacheKey",
    hotels: ["//HotelSummary", {
        hotel_id: "hotelId",
        name: "name",
        rooms: ["RoomRateDetailsList/RoomRateDetails", {
            rates: ["RateInfos/RateInfo", {
                currency: "ChargeableRateInfo/@currencyCode",
                non_refundable: "nonRefundable",
                price: "ChargeableRateInfo/@total"
            }],
            room_name: "roomDescription",
            room_type_id: "roomTypeCode"
        }]
    }],
    session_id: "/HotelListResponse/customerSessionId"
}

const result = transform(xml, template)
于 2017-06-08T22:38:51.077 回答
0

取而代之的是 xml2js,使用 xml2json,它使用特定的键将 xml 完全转换为 json。

于 2018-11-13T11:44:38.040 回答
0

$ 是具有默认配置的属性的位置。

由于 xml2js 将您的 XML 标记(例如 SD)显式解析为数组(使用 explicitArray=true - 无论哪种方式都有多个,并且您只能在 JSON 中为每个对象分配一个相似的键),因此您需要一个存储属性的地方, 这就是 $ 的用途。您可以使用(这是默认设置)强制创建数组或将其关闭。使用 mergeAttrs 您最终可能会得到您想要的结果。

如果这也是一种解决方案,您可以更改 attrkey。charkey 等也是如此。您可以在https://github.com/Leonidas-from-XIV/node-xml2js的 GitHub 上的 README 中找到整个配置选项- 最终转换为子项的选项可能适合您。

如果你根本不需要属性,你可以设置 ignoreAttrs=true。顺便一提; 解析器选项作为对象进入解析器构造函数,在您的情况下: new xml2js.Parser({...options});

于 2017-05-22T06:50:18.823 回答