nodejs elementtree npm xml parsing and merging

后端 未结 1 503
小鲜肉
小鲜肉 2021-01-16 21:31

I have a question on same module as I posted last time in below post. Seems like, it is quite difficult to deal with XML parsing. With elementTree having very mearge documen

相关标签:
1条回答
  • 2021-01-16 22:22

    Finally I was able to make it working with current lib. Please see my comments:

    'use strict';
    
    const et = require('elementtree');
    const path = require('path');
    const fs = require('fs');
    
    function populateXmlTemplate(id) {
    	//Please use path.join to make it cross-platform
    	var template_XML = path.join(__dirname, 'template.xml');
    	var sample_XML = path.join(__dirname, 'sample.xml');
    	var new_xml = path.join(__dirname, 'new.xml');
    
    	var data = fs.readFileSync(template_XML).toString();
    	var data1 = fs.readFileSync(sample_XML).toString();
    
    	var etree = et.parse(data);
    	var etree1 = et.parse(data1);
    
    	var root = etree.getroot();
    
    	var placeholder = root.find('./Profile');
    	root.remove(placeholder);
    
    	var profiles = etree1.findall('./Profile'); // Find the required profile.
    	for (var i = 0; i < profiles.length; i++) {
    		//If I get it right, it shouldn't be hardcoded
    		if (profiles[i].get('id') == id) {
    			var tmppro = profiles[i];
    		}
    	}
    
    	//After you removed the placeholder the number of children decreased
    	//So it should be 2, not 3.
    	//Also etree doesn't have insert method, please call root.insert
    	root.insert(2, tmppro);
    
    	//You have been writing the document a bit incorrectly.
    	var resultXml = etree.write();
    	fs.writeFileSync(new_xml, resultXml);
    }
    
    populateXmlTemplate('profile2');
    
    module.exports = {populateXmlTemplate};

    But you're right, the documentation is not good. It's mostly missing. So mostly I simply have been debugging it to see the available methods, also there are some tests in the lib repo.

    There are other modules to work with js. Please see this answer.

    0 讨论(0)
提交回复
热议问题