如何将Excel UsedRange的内容复制到数组中以便更快地阅读?

时间:2018-04-11 21:13:08

标签: c# excel office-interop excel-interop

我试图提高逐行从Excel工作表中读取单元格的应用程序的性能。我找到了这个解决方案

  

https://stackoverflow.com/a/25842904/1462656

     

您希望在一次操作中执行此操作:

object[,] objectArray = cSheet.get_Range("A1:C4").Value2; 
dataRange.Value2 = objectArray;

是否假设所有单元格都是Value2类型?

一般来说,我想知道如何将UsedRange的内容放入本地数组中以便更快地访问(而不是通过互操作来回传递)。但我事先并不知道它的大小,但我事先知道每列的细胞类型。它们是Value2和Formula的组合。

到目前为止我的代码

        Application application = new Application();
        application.Workbooks.Open(file);
        Workbook workbook = application.Workbooks.get_Item(1);
        Worksheet worksheet = workbook.Worksheets.get_Item(1);

        Range UsedRange = worksheet.UsedRange;
        int rows = UsedRange.Rows.Count;
        int cols = UsedRange.Columns.Count;

        object[,] objectArray = new object[rows,cols];

我不知道接下来该做什么。

我打算这样做

objectArray = (object[,])UsedRange.Range[?,?];

但我不知道使用上面找到的列数和行数来指定范围的语法。

最初我有一个这样的for循环非常慢

for (int rowIndex = 2; rowIndex < UsedRange.Rows.Count; rowIndex++){

    string str1= UsedRange.Rows.Cells[rowIndex, 0 + 1].Value2.ToString();
    string str2= UsedRange.Rows.Cells[rowIndex, 1 + 1].Formula as string;

}

2 个答案:

答案 0 :(得分:1)

重点是一步完成Excel操作,然后使用.Net object[,]。例如:

object[,] objectArray = new object[rows,cols];
  

我不知道下一步该做什么。

object[,] objectArray = shtName.get_Range("A1:Z100").Value2;

for (int row = 0; row < objectArray.GetLength(0); row++)
{
    for (int col = 0; col < objectArray.GetLength(1); col++)
    {
        Debug.WriteLine(objectArray[row,col].ToString());
    }
}

ps我今天没有测试过,非常忙碌

每次调用Excel时,都会有一个基础RPC调用被编组。

这也有帮助:https://stackoverflow.com/a/13983731/495455

答案 1 :(得分:1)

我无法将范围指定为单元格值,例如其他解决方案

shtName.get_Range("A1:Z100")

所以我缺少的是一种指定使用范围而不进入上述细胞范围的方法,我从这个例子中找到了答案

https://www.dotnetperls.com/excel-vbnet

        Range UsedRange = worksheet.UsedRange;

        object[,] objectArray = (object[,])UsedRange.Value[XlRangeValueDataType.xlRangeValueDefault];

        for (int row = 2; row < objectArray.GetUpperBound(0); row++)
        {
             string str1= (objectArray[row, 1] == null) ? string.Empty : objectArray[row, 1].ToString();

             string str2= (objectArray[row, 2] == null) ? string.Empty : objectArray[row, 2].ToString();

             //...etc
        }