0.1.7 • Published 8 years ago

elementtree v0.1.7

Weekly downloads
196,649
License
Apache-2.0
Repository
github
Last release
8 years ago

node-elementtree

node-elementtree is a Node.js XML parser and serializer based upon the Python ElementTree v1.3 module.

Installation

$ npm install elementtree

Using the library

For the usage refer to the Python ElementTree library documentation - http://effbot.org/zone/element-index.htm#usage.

Supported XPath expressions in find, findall and findtext methods are listed on http://effbot.org/zone/element-xpath.htm.

Example 1 – Creating An XML Document

This example shows how to build a valid XML document that can be published to Atom Hopper. Atom Hopper is used internally as a bridge from products all the way to collecting revenue, called “Usage.” MaaS and other products send similar events to it every time user performs an action on a resource (e.g. creates,updates or deletes). Below is an example of leveraging the API to create a new XML document.

var et = require('elementtree');
var XML = et.XML;
var ElementTree = et.ElementTree;
var element = et.Element;
var subElement = et.SubElement;

var date, root, tenantId, serviceName, eventType, usageId, dataCenter, region,
checks, resourceId, category, startTime, resourceName, etree, xml;

date = new Date();

root = element('entry');
root.set('xmlns', 'http://www.w3.org/2005/Atom');

tenantId = subElement(root, 'TenantId');
tenantId.text = '12345';

serviceName = subElement(root, 'ServiceName');
serviceName.text = 'MaaS';

resourceId = subElement(root, 'ResourceID');
resourceId.text = 'enAAAA';

usageId = subElement(root, 'UsageID');
usageId.text = '550e8400-e29b-41d4-a716-446655440000';

eventType = subElement(root, 'EventType');
eventType.text = 'create';

category = subElement(root, 'category');
category.set('term', 'monitoring.entity.create');

dataCenter = subElement(root, 'DataCenter');
dataCenter.text = 'global';

region = subElement(root, 'Region');
region.text = 'global';

startTime = subElement(root, 'StartTime');
startTime.text = date;

resourceName = subElement(root, 'ResourceName');
resourceName.text = 'entity';

etree = new ElementTree(root);
xml = etree.write({'xml_declaration': false});
console.log(xml);

As you can see, both et.Element and et.SubElement are factory methods which return a new instance of Element and SubElement class, respectively. When you create a new element (tag) you can use set method to set an attribute. To set the tag value, assign a value to the .text attribute.

This example would output a document that looks like this:

<entry xmlns="http://www.w3.org/2005/Atom">
  <TenantId>12345</TenantId>
  <ServiceName>MaaS</ServiceName>
  <ResourceID>enAAAA</ResourceID>
  <UsageID>550e8400-e29b-41d4-a716-446655440000</UsageID>
  <EventType>create</EventType>
  <category term="monitoring.entity.create"/>
  <DataCenter>global</DataCenter>
  <Region>global</Region>
  <StartTime>Sun Apr 29 2012 16:37:32 GMT-0700 (PDT)</StartTime>
  <ResourceName>entity</ResourceName>
</entry>

Example 2 – Parsing An XML Document

This example shows how to parse an XML document and use simple XPath selectors. For demonstration purposes, we will use the XML document located at https://gist.github.com/2554343.

Behind the scenes, node-elementtree uses Isaac’s sax library for parsing XML, but the library has a concept of “parsers,” which means it’s pretty simple to add support for a different parser.

var fs = require('fs');

var et = require('elementtree');

var XML = et.XML;
var ElementTree = et.ElementTree;
var element = et.Element;
var subElement = et.SubElement;

var data, etree;

data = fs.readFileSync('document.xml').toString();
etree = et.parse(data);

console.log(etree.findall('./entry/TenantId').length); // 2
console.log(etree.findtext('./entry/ServiceName')); // MaaS
console.log(etree.findall('./entry/category')[0].get('term')); // monitoring.entity.create
console.log(etree.findall('*/category/[@term="monitoring.entity.update"]').length); // 1

Build status

Build Status

License

node-elementtree is distributed under the Apache license.

@navify/clicordova-res-no-validations@aaa-mobile/cordova-plugin-aaamobile-diagnosticecpaytest@danielraban/cordova.plugins.diagnostic.hathway@springworks/android-plankancarlhopf-cordova-lib@everything-registry/sub-chunk-1568judpackjudpack-androidjudpack-commonjudpack-lib@traeger-industry/codabix-debug-runtime@totalpave/cordova-plugin-date@vihlix/capacitor-text-reader@wavemaker/wm-cordova-cli@xiangnanscu/xlsx-template@xnscu/xlsx-template@yukaii/ecpay_payment_nodejs@youtuosoft/plus-resartefaktasreaderakcordwin-testadmob-plusadformadd-typescript-file-to-projectadcutiladd-content-file-to-projectadxutilahcdchocobi-libcordova-commoncordova-configcordova-config-utilscordova-browsersync-primitivescordova-plugin-amplify-paycordova-plugin-amplify-paymentcordova-android-crash-auto-restartcordova-libcordova-lib-tmp4ccacordova-ioscordova-labs-local-webserver-kacordova-labs-local-webserver-klbcordova-kc-plugin-automatic-configcordova-plugin-call-directorycordova-android-transcordova-deploycordova-diagnostic-applaudplugincordova-diagnostic-plugin-applaudcordova-custom-configcordova-custom-config-kacordova-plugin-browsersynccordova-plugin-browsersync-gen2cordova-plugin-browsersync-xjpcordova-blackberry10cordova-plugin-app-scopecordova-air-update-cliconfig-cordovacordova-plugin-livereloadcordova-plugin-newplugincordova-plugin-navitia-sdk-uicordova-plugin-nearitcordova-plugin-navitia-sdkcordova-plugin-today-widgetcordova-plugin-remotecordova-plugin-pinchcordova-plugin-scannercordova-plugin-scanner-testcordova-plugin-settings-hookcordova-plugin-settings-hook-extendedcordova-plugin-webview-crosswalkcordova-plugin-webpackccacordova-plugin-crosswalk-webview-fixcordova-plugin-custom-configcordova-plugin-demotoastcordova-plugin-firebase-authcordova-plugin-firebase-auth-googlecordova-plugin-firebase-corecordova-plugin-kettlecordova-ubuntucordova-utilscordova-webpack-config-plugincordova-testabitcom.meenrios.samplecom.telerik.plugins.healthkit.ehrcordova-plugin-mfpcordova-pluscordova-rescordova-res-multi-imagecordova-res-no-validationcordova-plugins-firebaseecommerceanalyticscordova-windowscordova-windows-nufixcordova.plugins.diagnosticcordova.diagnostic.pluginbuild-global-statscapacitor-firebase-authenticationblueoak-buildd2l-web-package-readercsproj-utils
0.1.7

8 years ago

0.1.6

11 years ago

0.1.5

12 years ago

0.1.4

12 years ago

0.1.3

12 years ago

0.1.2

12 years ago

0.1.1

13 years ago

0.1.0

13 years ago