我试图提高逐行从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;
}
答案 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调用被编组。
答案 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
}