0
我有一個Excel工作簿(Spreadsheet)在我的驅動器帳戶中有多個工作表,其中有一個工作表有5000條記錄。使用Apps腳本電子表格獲得JSON的速度非常慢
我正在使用這個腳本(Apps腳本)從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;
}
爲什麼需要這麼長時間? 這個腳本有任何優化,你可以做得更快嗎? 我可以推薦什麼方法快速獲取記錄?
謝謝,我現在使用代碼傳遞給csv並且工作得很快 – seba123neo