Giter Site home page Giter Site logo

xml-to-json's Introduction

xml-to-json-stream

Simple module to convert XML to JSON with javascript

Download

npm install xml-to-json-stream

Public API

xml-to-json-stream only has two public methods xmlToJson and createStream . Use xmlToJson if you simply want to pass in some XML and access the resulting JSON in the callback function. Use createStream if you need to pipe some readable XML stream into a writable destination and convert the XML to JSON along the way.

The module currently accepts attributeMode as an option, which defaults to true . attributeMode decides whether XML attributes should be ignored or not.

const xmlToJson = require('xml-to-json-stream');
const parser = xmlToJson({attributeMode:false});

const xml = `
<employee id="123456">
    <name>Alex</name>
</employee>
`

parser.xmlToJson(xml, (err,json)=>{
    if(err) {
        //error handling
    }

    //json
    //{
    //  employee: {
    //      name: "Alex"
    //  }    
    //}
});

//the 'id' attribute of employee is ignored. If attributeMode was set to true or omitted, the json would have been:
// {
//   employee: {
//      id: "123456",
//      name: "Alex"
//   }    
// }

xmlToJson

const xmlToJson = require('xml-to-json-stream');
const parser = xmlToJson({attributeMode:false});

parser.xmlToJson(xml, (err,json)=>{
    if(err) {
        //error handling
    }

    //json is converted xml
});

createStream

createStream allows you to create a Node.js Transform stream that can be written to and read from. Consider a hypothetical weather service that only responds with XML data. createStream will remove some of the boilerplate for you by letting you pipe service responses through the parser/stream.

const xmlToJson = require('xml-to-json-stream');
const parser = xmlToJson();
const stream = parser.createStream();

const server = http.createServer((req,res)=>{

    http.get('http://someHypothecialXMLWeatherService/api', (response)=>{ //since response is a readable stream we can pipe it through our stream
        response.pipe(stream).pipe(res); //the client will receive the json representation of the XML response
    })
})

Or...

...If you have an XML file you want to convert on the fly via the command line $ cat file.xml | node app

const xmlToJson = require('xml-to-json-stream');
const fs = require('fs');

const parser = xmlToJson();
const stream = parser.createStream();
const jsonFile = fs.createWriteStream('jsonFile.json')

process.stdin.pipe(stream).pipe(jsonFile);

Additional Considerations

  • Comments are removed

  • Root elements are removed

  • If an element occurs multiple times in the same depth then that element will be represented as an array in the JSON

        <xml>
            <employee id="123" name="alex"></employee>
            <employee id="456" name="jon"></employee>
            <employee id="789" name="ashley"></employee>
        </xml>
    
        will turn into...
    
        {
            xml: {
                employee: [
                    {
                        id: "123",
                        name: "alex"
                    },
                    {
                        id: "456",
                        name: "jon"
                    },
                    {
                        id: "789",
                        name: "ashley"
                    }
                ]
            }
        }
    
    • If an element contains a textNode and attributes the textNode will have the key textNode
        <employee id="98765">Alex</employee>
        
        will turn into...
        
        employee: {
            id: "98765",
            textNode: "Alex"
        }
    
        and ...
    
        <employee>Alex</employee>
        
        will turn into...
    
        employee: "Alex"
    

    License: MIT

xml-to-json's People

Contributors

alabianca avatar nishit-rapidops avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.