如何使用XmlService检索值?

如何使用XmlService检索值?,xml,dom,google-apps-script,google-sheets,Xml,Dom,Google Apps Script,Google Sheets,这是我的一个后续问题 我必须使用脚本编辑器在Google电子表格中实现XML数据的提取。我试图从远程存储的XML文件中提取某些值。代码可以是静态的(索引?),因为结构是固定的,只有值会不时更改 XML如下所示: <?xml version='1.0' encoding='UTF-8'?> <response xmlns="http://www.xovis.com/sensor-api/v2"> <sensor-time timezone=&q

这是我的一个后续问题

我必须使用脚本编辑器在Google电子表格中实现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>

您可以通过选择特定的子对象在XML中向下搜索。 在下面的示例中,我将其设置为动态的,假设可能有多个
元素
度量
节点

这样做很快,而且没有经过测试。可能有一些拼写错误,但我认为机制应该很清楚。一定要检查一下房间


谢谢,但在使用代码时返回的错误与以前相同:TypeError:cannotcall方法“getChild”为null。(第68行,文件“Code”)var内容在运行调试模式时也为null调试outputDocument.getRootElement()时会发生什么情况?[17-12-19 14:26:13:171 CET]null但它返回[17-12-19 14:28:31:860 CET][Element:@dan_ke我已使用测试版本更新了我的答案。在以前的代码中,由于未提供名称空间,我未能选择内容节点。
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);
 
   
}
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())
            }
        }
    }
}