是否可以获取我的数据集的过滤条件。例如,如果我的一个列是“部门”,我过滤数据只显示“IT”。我们如何获得过滤后的标准“IT”。我需要将过滤后的标准放入我的GAS中以进行其他操作。
感谢。
答案 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)
如果你想在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)
在寻找这个问题的答案时,我提出了下一个解决方法:
最后一个数组可用于进一步处理工作表数据。 为了使脚本的效果更加生动,我使用脚本将使用过的单元格的背景设置为绿色。
这是最终用户付出的额外努力,但恕我直言,这是唯一可以仅使用过滤数据的方法。
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的回答,我写了以下函数:
//
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;
然后这样称呼它:
// 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;
比防止隐藏行的日志。您可以在以下位置看到它: Prueba script,注意项目必须在Google API控制台上启用Google表格API。
希望它有所帮助。谢谢!
答案 5 :(得分:0)
这在Google的问题跟踪器中以Issue #36753410的形式提出。
截至2018-04-12,他们已发布解决方案:
昨天我们发布了一些可以实现的新功能 使用Apps脚本处理过滤器:
- https://developers.google.com/apps-script/reference/spreadsheet/range#createFilter()
- https://developers.google.com/apps-script/reference/spreadsheet/sheet#getfilter
- https://developers.google.com/apps-script/reference/spreadsheet/filter
不幸的是,Apps脚本仍然没有确定方法 如果过滤器隐藏了给定的行或列。请参阅comment #157 使用Sheets Advanced Service的解决方法。
Filter课程可让您依次获得每列的FilterCriteria。