【问题标题】:Extremely slow to get JSON with Apps Script Spreadsheet使用 Apps Script Spreadsheet 获取 JSON 非常慢
【发布时间】:2016-05-02 12:52:01
【问题描述】:

我的驱动器帐户中有一个 Excel 工作簿(电子表格),其中包含多张工作表,其中一张有 5000 条记录。

我正在使用此脚本 (Apps Script) 从 Android 设备获取 JSON 格式的记录:如果记录很少,该脚本可以工作,但有很多记录永远不会完成。

    function traerRubros() {
  var libro = SpreadsheetApp.openByUrl('https://docs.google.com/spreadsheets/d/1-Vv3tsn7QYDa7rOsha4ebj9vJyjegG7j-xpDMbOOAuY/edit#gid=825509855');

  var sheet = libro.getSheetByName('Articulos');

  var json1 = convertSheet2JsonText(sheet);

  return JSON.stringify(json1);
}

function convertSheet2JsonText(sheet) {
  // first line(title)
  var colStartIndex = 1;
  var rowNum = 1;
  var firstRange = sheet.getRange(1, 1, 1, sheet.getLastColumn());
  var firstRowValues = firstRange.getValues();
  var titleColumns = firstRowValues[0];

  // after the second line(data)
  var lastRow = sheet.getLastRow();
  var rowValues = [];
  for(var rowIndex=2; rowIndex<=lastRow; rowIndex++) {
    var colStartIndex = 1;
    var rowNum = 1;
    var range = sheet.getRange(rowIndex, colStartIndex, rowNum, sheet.getLastColumn());
    var values = range.getValues();
    rowValues.push(values[0]);
  }

  // create json
  var jsonArray = [];
  for(var i=0; i<rowValues.length; i++) {
    var line = rowValues[i];
    var json = new Object();
    for(var j=0; j<titleColumns.length; j++) {
      json[titleColumns[j]] = line[j];
    }
    jsonArray.push(json);
  }
  return jsonArray;
}

为什么需要这么长时间? 您可以对此脚本进行任何优化以使其更快吗? 我可以推荐什么替代方法来快速获取记录?

【问题讨论】:

    标签: android json google-apps-script google-sheets


    【解决方案1】:

    在循环中执行 getRange() 或 getValues() 总是会使您的代码变慢。其次 getValues() 返回 Array[][]。无需将其复制到另一个数组中。

     // after the second line(data)
      var lastRow = sheet.getLastRow();
      var colStartIndex = 1;
      var rowStart = 2; // Column and Rows start at index 1
      var rowValues = sheet.getRange(rowStart, colStartIndex, sheet.getLastRow(),    sheet.getLastColumn()).getValues();
    
    // create json
      var jsonArray = [];
    ...
    ...
    

    【讨论】:

    • 谢谢,我现在正在使用代码传递给 csv 并且工作速度很快
    猜你喜欢
    • 2020-06-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多