我有一个包含数千行和最多“BP”的Excel文件。 我需要按列C和BP中的特定值过滤所有这些行。
我根据下面的代码测试了ClosedXML中的过滤器功能。
当我将过滤器应用于一列时,一切运行良好,数据保存在新文件中。
当我尝试应用两个过滤器时,最后执行的过滤器是应用的过滤器。
我试图将工作表用作范围/表,同样的过滤问题。
我最终创建了“rows”表达式,但是第1行(标题)被过滤掉了。
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");
我尝试直接对列进行过滤,作为一个范围,作为一个表,试图隐藏没有所需值的行。
所有这些都根据一列过滤或根本不过滤。
“expression.AddFilter(某个值).AddFilter(其他一些值);”没有帮助,因为我没有尝试在同一列上添加多个过滤器
“和/或”功能在同一列上执行相同的多个过滤器。
是否有人设法根据多列中的值进行过滤?
非常感谢任何建议。
答案 0 :(得分:0)
尝试下面找到的排序方法here
myRange.SortColumns.Add(firstColumnNumber, XLSortOrder.Ascending);
myRange.SortColumns.Add(secondColumnNumber, XLSortOrder.Ascending);
myRange.Sort();
答案 1 :(得分:0)
这是我的答案。我在一段时间内遇到了同样的问题。
键是排序,必须在定义过滤器后完成。
var excelTable = TableRange.CreateTable();
excelTable.AutoFilter.Column(26).AddFilter("Filter 1");
excelTable.AutoFilter.Column(26).AddFilter("Filter 2");
excelTable.AutoFilter.Sort(1, XLSortOrder.Ascending);