首页 > 解决方案 > 谷歌工作表没有将行复制到正确的工作表

问题描述

我使用电子邮件地址作为唯一标识符,将一张数据分成多张。

我正在使用我找到并编辑的某些脚本的变体,但使用的是 copyTo 而不是 appendRow。

问题是它似乎将特定数据集的最后一行复制到后续工作表中。

我认为这可能是因为我正在使用 getActiveSheet 而不是明确定位正确的工作表,所以我尝试这样做,使用类似:getSheetByName(emailAddress[i][0])。

但是,这不断出现空值。当我记录 emailaddress 的值时,查看记录器,这些值显示正确,所以不太确定为什么我得到空值。

以下是“有效”的脚本,但将最后一行复制到后续工作表。

  function myFunction() {
  
  var theWorkbook = SpreadsheetApp.getActiveSpreadsheet();
  var theSheet = theWorkbook.getSheetByName("Copied");
  
  // This var will contain all the values from column B -> The email addresses
  var theEmails = theSheet.getRange("B:B").getValues();

  // This var will contain all the rows
  var rows = theSheet.getDataRange().getValues();
  
  //Set the first row as the header
  var header = rows[0];

  //Store the Sheets already created
  var completedSheets = []

  //The last created Sheet
  var last = theEmails[1][0]


  for (var i = 1; i < theEmails.length; i++) {    

    //Check if the Sheet is already done, if not create the sheet
    if(!completedSheets.includes(theEmails[i][0])) {

      //Set the Sheet name = email address (except if there is no name, then = Blank)
      if (theEmails[i][0] === "") {
        var currentSheet = SpreadsheetApp.getActiveSpreadsheet().insertSheet("Blank");
      } else {
        var currentSheet = SpreadsheetApp.getActiveSpreadsheet().insertSheet(theEmails[i][0]);
      }


      //append the header
      currentSheet.appendRow(header);
      var rowtocopy = theSheet.getRange(i,1,1,8);
      rowtocopy.copyTo(currentSheet.getRange(currentSheet.getLastRow()+1, 1));
      completedSheets.push(theEmails[i][0])
      last = theEmails[i][0]
    } else if (last == theEmails[i][0]) {      
      
    // If the sheet is created append the row to the sheet
      var currentSheet = SpreadsheetApp.getActiveSpreadsheet();
      var activespreadsheet = SpreadsheetApp.getActiveSheet();
      var rowtocopy = theSheet.getRange(i,1,1,8);
      rowtocopy.copyTo(activespreadsheet.getRange(activespreadsheet.getLastRow()+1, 1));  
      
    }

  }
 

}

还有我试图命名工作表的代码片段(以及它的许多变体),尽管这会返回一个空错误。

else if (last == theEmails[i][0]) {      
  
// If the sheet is created append the row to the sheet
  var currentSheet = SpreadsheetApp.getActiveSpreadsheet();
   var activespreadsheet =SpreadsheetApp.getActive().getSheetByName(last);
   var rowtocopy = theSheet.getRange(i,1,1,8);
  rowtocopy.copyTo(activespreadsheet.getRange(activespreadsheet.getLastRow()+1, 1));  

我究竟做错了什么?

标签: google-apps-scriptgoogle-sheetscopyto

解决方案


这是典型的 Sheets 陷阱,值数组基于索引零,API 的“行”和“列”基于索引 1。

在您的for循环中,您对调用i中的值数组和 API“行”参数使用相同的索引getRange(row, ...)。任何使用 Sheets 的人都可能多次对自己这样做过。

更新你有的地方

var rowtocopy = theSheet.getRange(i,1,1,8);

var rowtocopy = theSheet.getRange(i + 1,1,1,8);

它会起作用。


推荐阅读