如何从未知大小的数组中选择一个范围?

时间:2019-04-17 09:58:30

标签: javascript google-apps-script google-sheets macros

我想创建一个宏来检索另一张工作表中的数据,但是我事先不知道行数,我想恢复行数。数据表每天或每月有不同的行数,因此我无法提前定义行数。

我尝试使用函数“ GetRange”,但是获取非空行的数量与非空单元格的数量无关。

我也尝试创建过滤器,但是我没有在文档中写内容的权限。

function myFunction() {

   // Get the sheet with DATA active 
   var spreadsheet = SpreadsheetApp.getActive();
   spreadsheet.setActiveSheet(spreadsheet.getSheetByName('DataSheet'), true);


//how can i get the Range of the last non empty cells ??
  var range = spreadsheet.getRange("A2:Axxx"); 

//i want to have an integer (number of lines with data)
  var values = range.getValue(); 


// after i do somes operations in these data but it's not important.
  for(var i=2 ; i< values ; i++) {            

      spreadsheet.duplicateActiveSheet();
      spreadsheet.getActiveSheet().setName('Lettre Relance' + i);
      spreadsheet.getRange('C12').activate();
      spreadsheet.getCurrentCell().setFormula('=Relance!A'+i);
  }
}

非常感谢您的回应!

1 个答案:

答案 0 :(得分:0)

我通常使用Simple Mail Merge tutorial中的代码将整个工作表的数据读入对象。您还可以使用Faster way to find the first empty row线程中的代码获取第一个空行,然后将范围设置为该行之前的所有内容。我使用@Mogsdad响应中的代码,该代码已复制到此处:

/**
 * Mogsdad's "whole row" checker.
 */
function getFirstEmptyRowWholeRow() {
  var sheet = SpreadsheetApp.getActiveSheet();
  var range = sheet.getDataRange();
  var values = range.getValues();
  var row = 0;
  for (var row=0; row<values.length; row++) {
    if (!values[row].join("")) break;
  }
  return (row+1);
}