Google表格应用脚本可根据每个标签的las列批量隐藏行

问题描述 投票:-2回答:1

我有一个谷歌表,有很多选项卡,其中一些有不同的布局

我需要一个脚本在所有选项卡上运行(并且能够排除某些选项卡)以隐藏每个选项卡上每行最后一列中包含1的行

这应该是批量隐藏,因为我有很多行,如果逐行隐藏它会超过执行时间

任何帮助将非常感谢

谢谢 !

google-apps-script google-sheets hide batch-processing
1个回答
-1
投票

您必须阅读每个工作表,跟踪最后一列中包含1的行的范围,并将这些范围隐藏1乘1.下面的代码尝试执行此操作。看看它是否适用于您的情况。在excludes数组中输入要排除的确切名称。

function test() {
  // get spreadsheet
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  // get all sheets
  var sheets = ss.getSheets();

  // put exact sheet names in array to exclude, sample ['Sheet1', 'Sheet2']
  var excludes = [];

  for (var i = 0; i < sheets.length; i++) {
    // if sheet is to exclude,do nothing
    if (excludes.indexOf(sheets[i].getName()) != -1) continue;
    // hide rows of this sheet
    hideRows(sheets[i]);
  }
}

function hideRows(sheet) {
  // variables
  var start = null,
    range = 0,
    flag = false;
  // read all values
  var values = sheet.getDataRange().getValues();

  // for each row
  values.forEach(function(row, idx) {
    // if row last col is 1, set up start and range
    if (row[row.length - 1] == 1) {
      if (flag) {
        range++;
      } else if (!flag) {
        start = idx + 1;
        range++;
        flag = true;
      }
      return;
    }
    // row last col is not 1, hide last found range of rows
    // reset variables
    if (flag) {
      sheet.hideRows(start, range);
      flag = false;
      start = null;
      range = 0;
    }
  });
}
© www.soinside.com 2019 - 2024. All rights reserved.