我想创建一个宏来检索另一张工作表中的数据,但是我事先不知道行数,我想恢复行数。数据表每天或每月有不同的行数,因此我无法提前定义行数。
我尝试使用函数“ 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);
}
}
非常感谢您的回应!
答案 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);
}