我有一个 Excel 文件,其中包含数千行和最多“BP”的列。 我需要按 C 列和 BP 列中的特定值过滤所有这些行。
我按照下面的代码测试了 ClosedXML 中的过滤器功能。
当我将过滤器应用于一列时,一切正常,并且数据保存在新文件中。
当我尝试应用两个过滤器时,最后执行的过滤器就是应用的过滤器。
我尝试将工作表用作范围/表格,同样的过滤问题。
我最终创建了“行”表达式,该表达式有效,但第一行(标题)被过滤掉。
public static void Filter(string source, string newFile)
{
using (var workbook = new XLWorkbook(source))
{
IXLWorksheet worksheet = workbook.Worksheet(1);
int salesFoundCell = worksheet.FirstRow().Cells().First(c => c.Value.ToString() == "Sales Order Description").Address.ColumnNumber;
int revenueFoundCell = worksheet.FirstRow().Cells().First(c => c.Value.ToString() == "Revenue recognition date").Address.ColumnNumber;
//worksheet.RangeUsed().SetAutoFilter().Column(salesFoundCell).EqualTo("Equipment Sale");
//worksheet.RangeUsed().SetAutoFilter().Column(revenueFoundCell).EqualTo("00.00.0000");
//var rows = worksheet.RowsUsed().Where(r => r.CellsUsed().Any(c => c.GetString().Contains("Equipment Sale")) &&
// r.CellsUsed().Any(c => c.GetString().Contains("00.00.0000")));
Console.WriteLine(rows.Count());
//workbook.SaveAs(newFile);
}
}
我还尝试了 ClosedXML wiki 上发布的方法,将工作表保存为 MemoryStream,重新应用过滤器,然后将其保存到新文件中。
这是简短版本:
public void Create(string filePath)
{
var wb = new XLWorkbook();
IXLWorksheet ws;
#region Multi Column
String multiColumn = "Multi Column";
ws = wb.Worksheets.Add(multiColumn);
// Add filters
ws.RangeUsed().SetAutoFilter().Column(2).EqualTo(3).Or.GreaterThan(4);
ws.RangeUsed().SetAutoFilter().Column(3).Between("B", "D");
// Sort the filtered list
ws.AutoFilter.Sort(3);
#endregion
using (var ms = new MemoryStream())
{
wb.SaveAs(ms);
var workbook = new XLWorkbook(ms);
#region Multi Column
workbook.Worksheet(multiColumn).AutoFilter.Column(3).EqualTo("E");
workbook.Worksheet(multiColumn).AutoFilter.Sort(3, XLSortOrder.Descending);
#endregion
workbook.SaveAs(filePath);
ms.Close();
}
}
我对以下两个表达式进行了多次迭代:
worksheet.RangeUsed().SetAutoFilter().Column(salesFoundCell).EqualTo("Equipment Sale");
worksheet.RangeUsed().SetAutoFilter().Column(revenueFoundCell).EqualTo("00.00.0000");
我尝试直接在列上进行过滤,作为范围,作为表格,试图隐藏没有所需值的行。
所有这些要么基于一列进行过滤,要么根本不过滤。
“表达式.AddFilter(某些值).AddFilter(某些其他值);”没有帮助,因为我不想在同一列上添加多个过滤器
“与/或”功能执行相同的操作,同一列上有多个过滤器。
有人设法根据多列中的值进行过滤吗?
非常感谢任何建议。
尝试以下找到的排序方法这里
myRange.SortColumns.Add(firstColumnNumber, XLSortOrder.Ascending);
myRange.SortColumns.Add(secondColumnNumber, XLSortOrder.Ascending);
myRange.Sort();
这是我的答案。我为同样的问题苦苦挣扎了一段时间。
关键是排序,这必须在定义过滤器之后完成。
var excelTable = TableRange.CreateTable();
excelTable.AutoFilter.Column(26).AddFilter("Filter 1");
excelTable.AutoFilter.Column(26).AddFilter("Filter 2");
excelTable.AutoFilter.Sort(1, XLSortOrder.Ascending);