npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

xml-to-json-stream

v1.1.0

Published

Simple module to convert XML to JSON with javascript

Downloads

212,291

Readme

xml-to-json-stream

Simple module to convert XML to JSON with javascript

Download

npm install xml-to-json-stream or npm install xml-to-json-stream -g Installing the package globally allows you to convert xml file to json files via the command line. cat config.xml | tojson > config.json . If you want to ignore xml attribute simply add the -no-attr flag.

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