从 Excel 获取数据 - 索引超出范围
Get Data From Excel - Index exceeds bounds
我正在尝试从 Excel 文件中获取数据。我知道 excel 中的索引从 1 开始,但在读取简单矩阵时,我仍然收到 Index exceeds bounds
错误。
这是我正在使用的一个简单方法:
public static string[,] ReadFromExcel(Worksheet excelSheet)
{
if (excelSheet == null) return new string[1,1];
Microsoft.Office.Interop.Excel.Range xlRange = excelSheet.UsedRange;
int firstRow = xlRange.Row;
int firstColumn = xlRange.Column;
int lastRow = xlRange.Row + xlRange.Rows.Count - 1;
int lastColumn = xlRange.Column + xlRange.Columns.Count - 1;
string[,] data = new string[xlRange.Rows.Count - xlRange.Row, xlRange.Columns.Count - xlRange.Column];
for (int i= 0; i<= lastRow - firstRow; i++)
{
for (int j= 0; j <= lastColumn - firstColumn; j++)
{
data[i,j] = (string)(excelSheet.Cells[firstRow + i][firstColumn + j] as Range).Value;
//When I try to read values I get an error
System.Windows.MessageBox.Show(data[i, j]);
}
}
return data;
}
我错过了什么?
"data" 数组的大小应与行数和列数相匹配:
string[,] data = new string[xlRange.Rows.Count, xlRange.Columns.Count];
虽然 Excel Interop 的起始索引是 1,而不是零,但计数是正确的,您不需要减去起始行和列。
我正在尝试从 Excel 文件中获取数据。我知道 excel 中的索引从 1 开始,但在读取简单矩阵时,我仍然收到 Index exceeds bounds
错误。
这是我正在使用的一个简单方法:
public static string[,] ReadFromExcel(Worksheet excelSheet)
{
if (excelSheet == null) return new string[1,1];
Microsoft.Office.Interop.Excel.Range xlRange = excelSheet.UsedRange;
int firstRow = xlRange.Row;
int firstColumn = xlRange.Column;
int lastRow = xlRange.Row + xlRange.Rows.Count - 1;
int lastColumn = xlRange.Column + xlRange.Columns.Count - 1;
string[,] data = new string[xlRange.Rows.Count - xlRange.Row, xlRange.Columns.Count - xlRange.Column];
for (int i= 0; i<= lastRow - firstRow; i++)
{
for (int j= 0; j <= lastColumn - firstColumn; j++)
{
data[i,j] = (string)(excelSheet.Cells[firstRow + i][firstColumn + j] as Range).Value;
//When I try to read values I get an error
System.Windows.MessageBox.Show(data[i, j]);
}
}
return data;
}
我错过了什么?
"data" 数组的大小应与行数和列数相匹配:
string[,] data = new string[xlRange.Rows.Count, xlRange.Columns.Count];
虽然 Excel Interop 的起始索引是 1,而不是零,但计数是正确的,您不需要减去起始行和列。