ClosedXML Excel按多列中的值过滤行

时间:2017-04-10 13:33:06

标签: c# excel windows-7 closedxml

我有一个包含数千行和最多“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(其他一些值);”没有帮助,因为我没有尝试在同一列上添加多个过滤器

“和/或”功能在同一列上执行相同的多个过滤器。

是否有人设法根据多列中的值进行过滤?

非常感谢任何建议。

2 个答案:

答案 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);