Google Docs和xml阅读

时间:2016-02-28 03:52:59

标签: javascript xml google-docs

我正在使用代码(下方)来阅读Google文档中的xml。如果xml看起来像这样(我感兴趣的部分):

,它会很有效
<row orderID="4452813795" charID="96255569" stationID="60011752" volEntered="1" volRemaining="1" minVolume="1" orderState="0" typeID="11134" range="32767" accountKey="1002" duration="90" escrow="0.00" price="20000.00" bid="0" issued="2016-02-28 02:05:29"/>

我想要的是volRemaining值,我的代码返回1.但是如果xml看起来像这样:

<row orderID="4452813795" charID="96255569" stationID="60011752" volEntered="1" volRemaining="1" minVolume="1" orderState="0" typeID="11134" range="32767" accountKey="1002" duration="90" escrow="0.00" price="20000.00" bid="0" issued="2016-02-28 02:05:29"/>
<row orderID="4452814032" charID="96255569" stationID="60011752" volEntered="1" volRemaining="1" minVolume="1" orderState="0" typeID="11134" range="32767" accountKey="1002" duration="90" escrow="0.00" price="20000.00" bid="0" issued="2016-02-28 02:05:47"/>

代码仍然返回1.我需要的是从这两行添加这些值,以便在这种情况下代码返回2(可能有更多这样的行,代码需要检查orderState =&#34; 0&#34 ;)

这是我的代码:

function getLevelByTypeFromRowset(rowset, id)
{
    var rows = rowset.getChildren("row");
    var level=null;
    var level2=0;
    for (var i=0;level==null && i<rows.length;i++)
    {
        var row=rows[i];
        var typeIdAttr=row.getAttribute("typeID");
        if (typeIdAttr && typeIdAttr.getValue()==id && row.getAttribute("orderState").getValue()==0)
        {
            level2=level2 + row.getAttribute("volRemaining").getValue();

          if (i = rows.length){
            level=level2;
          }
        }
    }
    return level;
}
function TradeVolume(id) {
  //id=3389;
  var idd="orders";
  var url = "http://some.url.com";
  var document = readXml(url);
  var level = null;
var rowsets = document.getRootElement().getChild("result").getChildren("rowset");
for (var i=0;level==null && i<rowsets.length;i++)
{
    var rowset=rowsets[i];
  var typeIdAttr=rowset.getAttribute("name");
        if (typeIdAttr && typeIdAttr.getValue()==idd)
        {
    level=getLevelByTypeFromRowset(rowset, id);
        }
}
  if (level==null){
    level = 0
  }
  return parseFloat(level);
}

我已经尝试了3个小时,但却无法提出任何想法......

编辑:

工作代码:

function getLevelByTypeFromRowset(rowset, id)
{
    var rows = rowset.getChildren("row");
    var level=0;
    for (var i=0;i<rows.length;i++)
    {
        var row=rows[i];
        var typeIdAttr=row.getAttribute("typeID");
        if (typeIdAttr && typeIdAttr.getValue()==id && row.getAttribute("orderState").getValue()==0)
        {
            level=parseInt(level) + parseInt(row.getAttribute("volRemaining").getValue());
        }
    }
    return level;
}

1 个答案:

答案 0 :(得分:1)

一个问题是if (i = rows.length)。你正在那里做作业,你显然是想要测试平等。赋值导致循环条件为假,因此循环提前终止。

因此,您可以将if条件更改为if (i == rows.length)。但是,该测试永远不会成立,因为循环条件包括&& i<rows.length。也许你想说if (i == rows.length - 1),以便if的主体在最后一次通过循环时被执行?但只有当 last row满足

时才会发生
(typeIdAttr && typeIdAttr.getValue()==id && row.getAttribute("orderState").getValue()==0)

我认为不是你想要的。

我希望你的意思是移动

      if (i == rows.length - 1) {
        level = level2;
      }

在前面if的块之外。但是,做同样事情的一种更简单的方法就是完全删除这个if块,并改变

return level;

return level2;