1
我在Google Apps脚本中编写脚本。方法“moveActiveSheet”在Google Apps脚本(JavaScript)中无法正常工作
目标:允许用户按每张表名中的日期对Google电子表格中的工作表/选项卡进行排序。
function sorter() {
var sp = SpreadsheetApp.getActiveSpreadsheet();
var sheets = sp.getSheets();
var sheet_metadata = get_and_sort_sheet_metadata(sheets)
for(var j = 0; j < sheet_metadata.length; j++) {
sp.setActiveSheet(sp.getSheetByName(sheet_metadata[j].name));
sp.moveActiveSheet(j + 1);
}
}
这是sheet_metadata的内容的一个例子:
[{date=false, name=A, index=1}, {date=false, name=B, index=2}, {date=1.391058E12, name=ARCHIVE: xname0 name: 1/30/2014 ID:145952, index=8}, {date=1.42173E12, name=ARCHIVE: zname1 name: 1/20/2015 ID:1459527232, index=7}, {date=1.4543892E12, name=ARCHIVE: wname3 name: 2/2/2016 ID:145952723299, index=6}, {date=1.4544756E12, name=ARCHIVE: dname4 name: 2/3/2016 ID:145952723266, index=5}, {date=1.454562E12, name=ARCHIVE: qname5 name: 2/4/2016 ID:1459500, index=4}, {date=1.4546484E12, name=ARCHIVE: qname6 name: 2/5/2016 ID:1459500, index=3}]
的日期值是.getTime的()的结果。名称是工作表的名称。索引是表单的原始索引。此阵列中对象的顺序是工作表应该放入的顺序。
sheet_metadata中的对象始终按正确的顺序排列。但是,for循环(请参阅上文)无法按正确的顺序放置页面。
换句话说,纸张最终的顺序与sheet_metadata中的纸张数据的顺序不一致。
为什么不能正常工作?