Node.js 无法将xml正确解析为json

Node.js 无法将xml正确解析为json,node.js,parsing,xml2js,Node.js,Parsing,Xml2js,我试图将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'

我试图将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>
正在将“$”添加到已解析的json中。如何避免它


正在寻找解决方案。提前感谢。

美元是默认配置下属性的位置

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

如果这也是一种解决方案,则可以更改attrkey。查基等人也是如此。您可以在GitHub上的自述文件中找到完整的配置选项,最终一个转换为子项的选项可能适合您


如果您根本不需要属性,可以将ignoreAttrs设置为true。顺便说一句解析器选项作为对象进入解析器构造函数,在您的例子中是:newxml2js.parser({…options})

这样的库通常会解析所有内容,有时会产生许多您不需要的属性

我就是为了这个目的而创作的

这样做的缺点是,您必须为希望转换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)

取而代之的是xml2json,使用xml2json可以准确地将xml转换为带有特定键的json。

是的,实际上我对这个平台非常陌生,所以任何示例代码片段都会让我的生活变得简单。当然:-)您有var parser=new xml2js.parser();在代码中,创建解析器实例。在解析器的构造函数中,您可以传递一个选项对象,如so var Parser=new xml2js.Parser({optionName:optionValue});可用的选项在我发布的GitHub自述中。因此,为了根据您的需要解析XML,我将使用一些选项。但是相关的可能是var parser=newxml2js.parser({mergeAttrs:true,attrkey:'ANYTHINGELSE'});-您可以补充一下,您希望如何将XML解析为JSON(它应该是什么样子的)?
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)