繁体   English   中英

如何使用getRange在Google表格中查找最后一行

[英]How find last line in a Google Sheet with getRange

我正在使用以下脚本查找和替换文本。 唯一的问题是该行:

var range = sheet.getRange("D2:D2000");

设置为2000时,它将在最后一行之后创建新行。我需要找到最后一行,然后更改此行代码。 我迷路了 :(

我的总脚本如下:

 function runReplaceInSheet() { var spreadsheet = SpreadsheetApp.openById("1NK-pmvrJoSqKSgx2zRCAcRKGjk8SiiSsfwwerhfdM1SE"); // UPDATE ID var sheet = SpreadsheetApp.setActiveSheet(spreadsheet.getSheets()[0]); // UPDATE number in square brackets var range = sheet.getRange("D2:D2000"); // get the current data range values as an array // Lesser calls to access the sheet, lower overhead var startRow = 2; // First row of data to process var numRows = 2; // UPDATE number of rows to process // Fetch the range of cells var dataRange = sheet.getRange(startRow, 4, numRows, 1) // Numbers of rows to process // Fetch values for each row in the Range var data = dataRange.getValues(); for (var i = 0; i < data.length; ++i) { var row = data[i]; var v = row[3]; // edit: don't need this var values = range.getValues(); // Replace Names replaceInSheet(values, '1', 'Active'); replaceInSheet(values, '0', 'Inctive'); //write the updated values to the sheet, again less call;less overhead range.setValues(values); } } function replaceInSheet(values, to_replace, replace_with) { //loop over the rows in the array for (var row in values) { //use Array.map to execute a replace call on each of the cells in the row. var replaced_values = values[row].map(function(original_value) { return original_value.toString().replace(to_replace, replace_with); }); //replace the original row values with the replaced values values[row] = replaced_values; } } 

您可以使用sheet.getDataRange()返回一个范围,该范围描述其中包含一些数据的图纸区域。

如果只需要列D2:d,则可以执行此操作

var range = sheet.getDataRange();
range = range.offset (1,3,range.getNumRows()-1,1);

或者您可以像这样将数据放入一维数组中

var values = sheet.getDataRange().getValues().slice(1)
.map (function (d) {
    return d[3];
});

有很多方法。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM