Google App脚本/电子表格 - 如何获取过滤条件?

时间:2012-07-25 08:00:17

标签: google-apps-script

是否可以获取我的数据集的过滤条件。例如,如果我的一个列是“部门”,我过滤数据只显示“IT”。我们如何获得过滤后的标准“IT”。我需要将过滤后的标准放入我的GAS中以进行其他操作。

感谢。

6 个答案:

答案 0 :(得分:4)

尝试使用此示例进行简单过滤。它将从第一列过滤信息(将XXX更改为有意义的内容):

  function onOpen(){

  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var filterMenuEntries = [{name: "filter Column1", functionName: "filter"}];
  ss.addMenu("choose filter", filterMenuEntries);

  }

 function filter(){

 var sheet = SpreadsheetApp.getActiveSheet();
 var rows = sheet.getDataRange();
 var numRows = rows.getNumRows();
 var values = rows.getValues();

 for (var i=1; i <=numRows -1; i++){

   var row =values[i];

   // Column value
   var myValue = row[0];

   // filter value 
   if (myValue == "XXX"){

     sheet.hideRows(i+1);

     }

  }

}

答案 1 :(得分:3)

Google电子表格已有一个FILTER公式(I always use this page to remind me how to do it)。例如,如果您的数据看起来像这样

  A
1 Department
2 IT Department (Edinburgh)
3 Department of IT
4 Other Department

要获得已过滤的列表,您可以使用公式

=FILTER(A:A;FIND("IT",A:A)>0)

Working example here

如果你想在Apps脚本中完全做某事,Romain Vialard写了一个带有过滤功能的Managed Library。以下是instructions for installing and using the 2D Array2 library

答案 2 :(得分:3)

现在可以使用过滤器,最近推出了高级表格服务: 以下是article

的链接

以下是一些如何操作的摘要:

function setSheetBasicFilter(ssId, BasicFilterSettings) {
  //requests is an array of batchrequests, here we only use setBasicFilter
  var requests = [
    {
      "setBasicFilter": {
        "filter": BasicFilterSettings
      }
    }
  ];
  Sheets.Spreadsheets.batchUpdate({'requests': requests}, ssId);
}

答案 3 :(得分:0)

在寻找这个问题的答案时,我提出了下一个解决方法:

  • 在工作表中应用过滤器;
  • 为过滤后的颜色(因此 可见的)单元格(在F列中的示例代码为红色);
  • 运行脚本:
    • 以数组颜色读取背景颜色(列F)
    • 迭代此数组
    • 建立可见的新行号数组。

最后一个数组可用于进一步处理工作表数据。 为了使脚本的效果更加生动,我使用脚本将使用过的单元格的背景设置为绿色。

这是最终用户付出的额外努力,但恕我直言,这是唯一可以仅使用过滤数据的方法。

function getFilterdData(){  
   var s = SpreadsheetApp.getActive();
   var sheet= s.getSheetByName('Opdrachten en aanvragen');//any sheet
   var rows = new Array();
   var colors = sheet.getRange(1, 6, sheet.getLastRow(), 1).getBackgrounds();
   for(var i = 0; i < colors.length; i++){
       if(colors[i] == "#ff0000"){
         var rowsIndex = rows.length;
         rows[rowsIndex] = i+1;
         sheet.getRange(i+1, 6).setBackground("#d9ead3")
         }
       }
    }

答案 4 :(得分:0)

根据mhawksey的回答,我写了以下函数:

&#13;
&#13;
//
function celdasOcultas(ssId, rangeA1) {  
  // limit what's returned from the API
  var fields = "sheets(data(rowMetadata(hiddenByFilter)),properties/sheetId)";
  var sheets = Sheets.Spreadsheets.get(ssId, {ranges: rangeA1, fields: fields}).sheets;
  if (sheets) {
    return sheets[0].data[0].rowMetadata;
  }
}
&#13;
&#13;
&#13;

然后这样称呼它:

&#13;
&#13;
    // i.e. : ss = spreadsheet, ranges = "Hoja 2!A2:A16"
    Logger.log(range.getA1Notation());
    var ocultas = celdasOcultas(ss.getId(), sheetName + "!" + range.getA1Notation());
    // Logger.log(ocultas);
    var values = range.getValues();
    for (var r = 0; r < values.length; r++) {
      if (!ocultas[r].hiddenByFilter) {
        values[r].forEach( function col(c){
          Logger.log(c);
        });
      }
      //range.setBackground("lightcoral");
    }
&#13;
&#13;
&#13;

比防止隐藏行的日志。您可以在以下位置看到它: Prueba script,注意项目必须在Google API控制台上启用Google表格API。 enter image description here

希望它有所帮助。谢谢!

答案 5 :(得分:0)

这在Google的问题跟踪器中以Issue #36753410的形式提出。

截至2018-04-12,他们已发布解决方案:

  

昨天我们发布了一些可以实现的新功能   使用Apps脚本处理过滤器:

           

不幸的是,Apps脚本仍然没有确定方法   如果过滤器隐藏了给定的行或列。请参阅comment #157   使用Sheets Advanced Service的解决方法。

Filter课程可让您依次获得每列的FilterCriteria