注意:这是从Backup Google apps script not running
派生的后续问题下面的代码运行时出现了一些问题,我将它们缩小到只有1.我收到了错误
范围宽度不正确,为1,但应为18(第41行,文件"更新备份数据")
这是违规行
archiveSheet.getRange(archiveSheet.getLastRow() + 1, 1, data.length, rng.getWidth()+1).setValues(data);
以下链接用于包含虚拟信息的工作表副本。 https://docs.google.com/spreadsheets/d/1DR8XpNlRdZa17KqgnfBX3hxWKP5W4vrRJ_lj5uPNMlU/edit?usp=sharing
以下是代码
function dataBackup()
{
var inputSS = SpreadsheetApp.getActiveSpreadsheet();
var archiveSS = SpreadsheetApp.openById('1uPA_4CRmv2wkqe1uljViJ-1z1NTNDmwS3aE6TDowe88');
var sheetNames = ['AM trip', 'PM trip', 'Pool / Beach', 'Night Dive'];
for (var i=0; i<sheetNames.length; i++)
{
var inputSheet = inputSS.getSheetByName(sheetNames[i]);
var archiveSheet = archiveSS.getSheetByName(sheetNames[i]);
var date=inputSheet.getRange('A2').getValue();
var rng=inputSheet.getRange('E7:U37');
var dataA=rng.getValues();
var data=[];
for(var j=0;j<dataA.length;j++)
{
if(dataA[j][0] && dataA[j][1])
{
data.push([dataA[j].splice(0,0,date)]);
}
}
var dv=archiveSheet.getRange(archiveSheet.getLastRow(), 1).getValue();
date=(typeof(dv)!='undefined')?dv:'No Date Found';
if (data.length>0)
{
archiveSheet.insertRowsAfter(archiveSheet.getLastRow(), data.length);
archiveSheet.getRange(archiveSheet.getLastRow() + 1, 1, data.length, rng.getWidth()+1).setValues(data);
}
else
{
archiveSheet.insertRowsAfter(archiveSheet.getLastRow(), 1);
archiveSheet.getRange(archiveSheet.getLastRow() + 1, 1, 1, 2).setValues([[date, 'No Data']]);
}
}
}
该脚本用于复制选择e7-U37中的信息并粘贴到存档表中,并将从单元格A2中获取的日期放入存档表的第一列,如果没有信息,则“#34;无数据&#34;进入。 这是存档测试表。 https://docs.google.com/spreadsheets/d/1uPA_4CRmv2wkqe1uljViJ-1z1NTNDmwS3aE6TDowe88/edit?usp=sharing
答案 0 :(得分:0)
从您的脚本中,我认为因为data
的每个元素(2维数组)的长度与rng.getWidth()+1
不同,所以会发生错误。那么下面的修改呢?
archiveSheet.getRange(archiveSheet.getLastRow() + 1, 1, data.length, rng.getWidth()+1).setValues(data);
archiveSheet.getRange(archiveSheet.getLastRow() + 1, 1, data.length, data[0].length).setValues(data);
顺便问一下,你会在下面做什么?
var data = [];
for(var j=0;j<dataA.length;j++) {
if(dataA[j][0] && dataA[j][1]) {
data.push([dataA[j].splice(0,0,date)]);
}
}
您在其他部分使用data
,但在此处data
似乎变为[[[]], [[]], [[]], ...
。如果这是你想要的结果,我认为这没问题。另外我认为这部分可能与错误有关。
如果我误解了你的问题,我很抱歉。