ClosedXML Excel 按多列中的值过滤行

问题描述 投票:0回答:2

我有一个 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(某些其他值);”没有帮助,因为我不想在同一列上添加多个过滤器

“与/或”功能执行相同的操作,同一列上有多个过滤器。

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

非常感谢任何建议。

c# excel windows-7 closedxml
2个回答
0
投票

尝试以下找到的排序方法这里

myRange.SortColumns.Add(firstColumnNumber, XLSortOrder.Ascending);
myRange.SortColumns.Add(secondColumnNumber, XLSortOrder.Ascending);
myRange.Sort();

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);
© www.soinside.com 2019 - 2024. All rights reserved.