我需要这个脚本处理一个大的20k行,50列的大表。
截至目前,该脚本只能在耗尽时间之前处理10k行。
我试图尽可能地进行优化,但我担心自己已经遇到了我的困境:
这是我现在的代码:
function updateValues() {
var ws1 = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("FINAL").getDataRange();
var ws3List = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("WS2").getDataRange().getValues();
var ws2List = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("WS3").getDataRange().getValues();
var results = new Array;
var data1 = ws1.getValues();
var data1Length = data1.length;
var ws2Length = ws2List.length;
var ws3Length = ws3List.length;
var data1LengthHorizontal = data1[1].length;
for ( var i = 2; i < data1Length; i++ ) {
var iterHotel = data1[i][0];
results[i-2] = [];
for ( var nn=0; nn < ws2Length; ++nn ){
if (iterHotel == ws2List[nn][2]){
var ws2Code = ws2List[nn][4];
break;
}
}
// First Vlookup
var ws3Check;
for ( var nn=0; nn < ws3Length; ++nn ){
if (iterHotel == ws3List[nn][0]){
ws3Check = true;
break;
}
ws3Check = false;
}
// Second Vlookup
var score;
var countries = data1[0];
if (ws3Check) {score = aCalculator1(ws2Code);} else {score = aCalculator2(ws2Code);}
for ( var i1 = 2; i1 < data1LengthHorizontal; i1++){
if (data1[0][i1] == "ALL" || countries[i1].indexOf(data1[i][1]) > -1) {results[i-2][i1-2] = score;}
else {results[i-2][i1-2] = 1;}
}
}
var toCopy = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("FINAL").getRange(3, 3, data1Length - 2, data1LengthHorizontal - 2); //HardCoded Starting Point
toCopy.setValues(results);
}
function aCalculator1(ws2Code) {
switch (ws2Code) {
case 3:
return 75;
case 2:
return 75;
case 1:
return 95;
case 0:
return 1;
default:
return 1;
}
}
function aCalculator2(ws2Code) {
switch (ws2Code) {
case 3:
return 10;
case 2:
return 10;
case 1:
return 10;
case 0:
return 1;
default:
return 1;
}
}
你怎么看?你能看到要调整的东西吗?我该如何处理这个问题?也许拆分块?
PS:对不起如果我在更改名字时将一些变量搞砸了以便发布。
干杯,
答案 0 :(得分:1)
好吧,无论何时拨打谷歌图书馆,都需要花费时间。
这意味着如果你设法以某种方式将这两行排除在循环之外,那么你很可能会成功。
var toCopy = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("FINAL").getRange(3, 3, data1Length - 2, data1LengthHorizontal - 2); //HardCoded Starting Point
toCopy.setValues(results);
在循环内部尝试仅使用数组,记住索引,行行等,然后根据数据调用getRange
和setValues
外部循环你在循环中保存了。