这是我recent task
的后续问题我必须使用脚本编辑器在googles电子表格中使用javascript实现xml数据的提取。我正在尝试从远程存储的XML文件中提取某些值。代码可以是静态的(索引?),因为结构是固定的,只有值会不时变化。
XML如下所示:
<?xml version='1.0' encoding='UTF-8'?>
<response xmlns="http://www.xovis.com/sensor-api/v2">
<sensor-time timezone="Europe/Berlin">2017-12-18T17:00:02+01:00</sensor-time>
<status>
<code>OK</code>
</status>
<content>
<elements>
<element>
<element-id>0</element-id>
<element-name>count/element-name>
<sensor-type>somesensor</sensor-type>
<data-type>LINE</data-type>
<from>2017-10-29T16:00:00+01:00</from>
<to>2017-10-29T17:00:00+01:00</to>
<resolution>ONE_HOUR</resolution>
<measurements>
<measurement>
<from>2017-10-29T16:00:00+01:00</from>
<to>2017-10-29T17:00:00+01:00</to>
<values>
<value label="fw">145</value>
<value label="bw">1</value>
</values>
</measurement>
</measurements>
</element>
</elements>
</content>
<sensor-info>
<serial-number>D5:88:63:98:AA:E2</serial-number>
<ip-address>192.168.1.99</ip-address>
<name>somename</name>
<group></group>
<device-type>XYZ</device-type>
</sensor-info>
</response>
我现在面临的问题是,我没有工作的想法,如何深入挖掘水平以检索值145和1.我想我必须使用属性fw / bw。
<value label="fw">145</value>
<value label="bw">1</value>
到目前为止,我的代码返回错误:
找不到方法getChild()。 (第53行,文件“代码”)
function xmlRead(){
var url = 'SOMEURL';
var responseXML = UrlFetchApp.fetch(url).getContentText();
var outputDocument = XmlService.parse(responseXML);
var ns = XmlService.getNamespace("http://www.xovis.com/sensor-api/v2");
var out = outputDocument.getRootElement().getChildren()[2].getChildren();
var fw = out.getChild();
Logger.log(out);
}
答案 0 :(得分:2)
您可以通过选择特定子项向下深入查看XML。
在下面的示例中,我将其设置为动态,假设可能有多个element
和measurement
个节点。
快速制作并未经过测试。可能会有一些错别字,但我认为机制应该是明确的。请务必查看reference guide。
var xml = '<?xml version=\'1.0\' encoding=\'UTF-8\'?><response xmlns="http://www.xovis.com/sensor-api/v2"><sensor-time timezone="Europe/Berlin">2017-12-18T17:00:02+01:00</sensor-time><status><code>OK</code></status><content><elements><element><element-id>0</element-id><element-name>count</element-name><sensor-type>somesensor</sensor-type><data-type>LINE</data-type><from>2017-10-29T16:00:00+01:00</from><to>2017-10-29T17:00:00+01:00</to><resolution>ONE_HOUR</resolution><measurements><measurement><from>2017-10-29T16:00:00+01:00</from><to>2017-10-29T17:00:00+01:00</to><values><value label="fw">145</value><value label="bw">1</value></values></measurement></measurements></element></elements></content><sensor-info><serial-number>D5:88:63:98:AA:E2</serial-number><ip-address>192.168.1.99</ip-address><name>somename</name><group></group><device-type>XYZ</device-type></sensor-info></response>';
function myFunction() {
var outputDocument = XmlService.parse(xml);
var ns = XmlService.getNamespace("http://www.xovis.com/sensor-api/v2");
var content = outputDocument.getRootElement().getChild('content', ns);
var elements = content.getChild('elements', ns).getChildren('element', ns);
for (var i = 0; i < elements.length; i++) { // Loop over each element
Logger.log('Element ID: '+elements[i].getChild('element-id', ns).getText());
var measurements = elements[i].getChild('measurements', ns).getChildren('measurement', ns);
for (var j = 0; j < measurements.length; j++) { // Loop over each measurement
Logger.log('Measurement from: '+measurements[j].getChild('from', ns).getText())
var values = measurements[j].getChild('values', ns).getChildren('value', ns);
for (var k = 0; k < values.length; k++) { // loop over each value
Logger.log('Value: '+values[k].getText())
}
}
}
}