13

我正在使用 EPPlus 将数据从 excel 读取到数据表中。

在读取了 10 行记录的 excel 表后,我通过删除现有数据来修改 excel 表并仅保留一行数据。但是,当我阅读修改后的 excel 时,它仍然会读取 10 行(1 行带有值并保留为空字段)到数据表。

怎么能限制这个?我正在使用以下代码来阅读 Excel。

using (var pck = new OfficeOpenXml.ExcelPackage())
{
    using (var stream = File.OpenRead(FilePath))
    {
        pck.Load(stream);
    }
    var ws = pck.Workbook.Worksheets.First();                   
    bool hasHeader = true; // adjust it accordingly(this is a simple approach)
    foreach (var firstRowCell in ws.Cells[1, 1, 1, ws.Dimension.End.Column])
    {
        DSClientTransmittal.Tables[0].Columns.Add(hasHeader ? firstRowCell.Text : string.Format("Column {0}", firstRowCell.Start.Column));
    }
    var startRow = hasHeader ? 2 : 1;
    for (var rowNum = startRow; rowNum <= ws.Dimension.End.Row; rowNum++)
    {
        //var wsRow = ws.Cells[rowNum, 1, rowNum, ws.Dimension.End.Column];
        var wsRow = ws.Cells[rowNum, 1, rowNum, DSClientTransmittal.Tables[0].Columns.Count];
        var row = DSClientTransmittal.Tables[0].NewRow();
        foreach (var cell in wsRow)
        {
            try
            {
                object cellValue = cell.Value;
                //row[cell.Start.Column - 1] = cell.Text;
                row[cell.Start.Column - 1] = cellValue.ToString().Trim();
                //cell.Style.Numberformat.Format = "@";
                //row[cell.Start.Column - 1] = cell.Text;
            }
            catch (Exception ex) { }
        }
        DSClientTransmittal.Tables[0].Rows.Add(row);
    }
    pck.Dispose();
}   

当我使用 Interop excel 读取 excel 时,同样的问题被 clearformat()类似的方法克服了

ws.Columns.ClearFormats();
xlColCount = ws.UsedRange.Columns.Count;

Epplus open xml中是否有任何等价物?如何获得修改后的 Excel 的实际使用范围?

4

2 回答 2

10

仅删除某些单元格中的数据时,没有内置方法可以指示不应考虑行。

Dimension尽可能接近,但Dimension如果任何列包含数据,或者上面或下面的任何行包含数据,则行包含在行中。

但是,您可以尝试确定是否应该在 for 循环中跳过一行。例如,如果您总是只删除前 4 列中的数据,那么您可以尝试:

if(!ws.Cells[rowNum, 1, rowNum, 4].All(c => c.Value == null))
{
    //Continue adding the row to the table
}

该描述并未指示跳过一行的标准,但您明白了。

于 2015-12-08T08:53:29.840 回答
3

首先,我不是 C# 程序员,但我认为我有一个使用 Excel VBA 脚本工作的解决方案。您可能能够使用 C 运行此 Excel VBA 代码,或者深入了解如何使用 C+ 完成相同的事情。

您遇到的问题与 Excel 处理工作表工作大小的方式有关。如果您在第 1 百万行中输入数据,然后删除该单元格,Excel 仍将工作表显示为具有 100 万行。

我测试了这个 Excel VBA 代码,它成功删除了所有完全为空的行,然后重置了工作表大小。

Sub DelEmptyRowsResizeWorksheet()
  Dim i As Long, iLimit As Long
    iLimit = ActiveSheet.UsedRange.Rows.Count
  For i = iLimit To 1 Step -1
    If Application.CountA(Cells(i, 1).EntireRow) = 0 Then
       Cells(i, 1).EntireRow.Delete
    End If
  Next i
   iLimit = ActiveSheet.UsedRange.Rows.Count   ' resize the worksheet based on the last row with data
End Sub

要在没有脚本的情况下手动执行此操作,请首先删除工作表底部(或右侧的列)的所有空行,保存它,然后关闭并重新打开工作簿。我发现这也会重置 Excel 工作簿的大小。

于 2015-12-08T19:51:46.280 回答