繁体   English   中英

Google javascript - 访问和重命名数字对象名称

[英]Google javascript - accessing and renaming numeric object names

我将json数据导入到google脚本中:

var doc = Utilities.jsonParse(txt);

我可以访问大多数这样的对象......

var date = doc.data1.dateTime;
var playerName = doc.data1.playerName;
var playerId = doc.data1.playerID;
var teamNumber = doc.data2.personal.team;

我需要访问的一堆对象将数字作为对象名称...

doc.data2.personal.team.87397394.otherdata
doc.data2.personal.team.87397395.otherdata
doc.data2.personal.team.87397396.otherdata
doc.data2.personal.team.87397397.otherdata

...但是当我尝试用...读取数据时

var teamId = doc.data2.personal.team.87397394;

...我收到错误“丢失;在陈述之前。”

我试过这个......

var teamId = doc.data2.personal.team[87397394];

...并在日志中获得“teamId undefined”。

我也用同样的结果把它绑起来......

var teamId = doc.data2.personal.team[+'6803761'];

我可以使用“For In”非常轻松地将名称作为字符串读取,但无法访问对象本身。 到目前为止我发现的每个例子都使用了括号,所以我很难接下来要尝试什么。

谢谢! 布赖恩

UPDATE

我根据您的建议使用此方法将对象名称转换为变量并使用括号中的变量。 没有错误,但var测试仍然是“未定义的”......

for(var propertyName in doc.data2.personal.team) {
    // propertyName is what you want
    // you can get the value like this: myObject[propertyName]
    Logger.log (propertyNames);
    var test = doc.data2.personal.team[propertyName];
}

日志显示对象名称,如预期的那样......
87397394
87397395
87397396
87397397

我认为这是Google实施中的一个错误。 这是一个例子,如果有人想验证它。 测试将返回undefined ...

function myFunction1() {
  var txt = UrlFetchApp.fetch("http://www.hersheydigital.com/replays/replays_1.json").getContentText();
  var doc = Utilities.jsonParse(txt);
  for(var propertyName in doc.datablock_battle_result.vehicles) {
      Logger.log (propertyName);
      var test = doc.datablock_battle_result.vehicles[propertyName];
   }
}

问题似乎出现在Utitlies.jsonParse 以下工作正常

var txt = UrlFetchApp.fetch("http://www.hersheydigital.com/replays/replays_1.json").getContentText();
var doc = JSON.parse(txt);
for(var propertyName in doc.datablock_battle_result.vehicles) {
    var vehicle = doc.datablock_battle_result.vehicles[propertyName];
    Logger.log('Vehicle id is ' + propertyName);
    Logger.log('Vehicle value is  ' + JSON.stringify(vehicle));
    break;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM