范围宽度错误

时间:2017-12-23 19:37:52

标签: google-apps-script google-sheets

注意:这是从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

1 个答案:

答案 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似乎变为[[[]], [[]], [[]], ...。如果这是你想要的结果,我认为这没问题。另外我认为这部分可能与错误有关。

如果我误解了你的问题,我很抱歉。