[英]Slow Performance When Reading Excel With Microsoft.office.Interop.Excel
[英]Reading range by Microsoft.Office.Interop.Excel
我想从Excel中读取很多单元格到C#中的二维数组。 使用Microsoft.Office.Interop.Excel并逐个读取单元格太慢了。 我知道如何将数组写入范围( Microsoft.Office.Interop.Excel真的很慢 ),但我想在相反的方向做
_Excel.Application xlApp = new _Excel.Application();
_Excel.Workbook xlWorkBook;
_Excel.Worksheet xlWorkSheet;
object misValue = System.Reflection.Missing.Value;
xlWorkBook = xlApp.Workbooks.Open(path);
xlWorkSheet = xlWorkBook.Worksheets["Engineering BOM"];
_Excel.Range range = (_Excel.Range)xlWorkSheet.Cells[1, 1];
range = range.get_Resize(13000, 9);
string[,] indexMatrix = new string[13000, 9];
// below code should be much faster
for (int i = 1; i < 1300; i++)
{
for (int j = 1; j < 9; j++)
{
indexMatrix[i, j] = xlWorkSheet.Cells[i, j].Value2;
}
}
因此,我希望从数组中的单元格范围中获取值(范围大小与数组大小完全相同)。 现在app正在逐个单元地读取数据并将数据写入数组但速度太慢。 有没有办法直接将整个范围复制到单元格?
先感谢您 :)
你可以试试这个,它应该更快但是:
您必须使用数据表 (在这种情况下,最好使用数据表而不是多维数组。)
你不需要再关心范围了 。
那我们该怎么办? 连接到Excel并进行查询以选择所有数据并填充数据表。 我们需要的? 几行代码。
首先我们声明我们的连接字符串:
对于Excel 2007或更高版本( *.XLSX
文件)
string connectionString = string.Format("Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties=\"Excel 12.0 Xml;HDR=No;IMEX=1\";", fullPath);
对于Excel 2003 ( *.XLS
文件)
string connectionString = string.Format("Provider=Microsoft.Jet.OLEDB.4.0; data source={0}; Extended Properties=\"Excel 8.0;HDR=No;IMEX=1\";", fullPath);
其中fullPath
是excel文件的完整文件路径
现在我们必须创建连接并填充数据表:
OleDbConnection SQLConn = new OleDbConnection(strConnectionString);
SQLConn.Open();
OleDbDataAdapter SQLAdapter = new OleDbDataAdapter();
string sql = "SELECT * FROM [" + sheetName + "$]";
OleDbCommand selectCMD = new OleDbCommand(sql, SQLConn);
SQLAdapter.SelectCommand = selectCMD;
SQLAdapter.Fill(dtXLS);
SQLConn.Close();
其中sheetName
是您的工作表名称, dtXLS
是填充了所有Excel工作值的数据表。
这应该更快。
我想这个范围在某种程度上定义了一个'数据表'。 如果这是正确的,那么最快就是使用OleDb或ODbc读取数据(并且甚至不需要安装excel):
DataTable tbl = new DataTable();
using (OleDbConnection con = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;" +
$"Data Source={path};" +
@"Extended Properties=""Excel 12.0;HDR=Yes"""))
using (OleDbCommand cmd = new OleDbCommand(@"Select * from [Engineering BOM$A1:i13000]", con))
{
con.Open();
tbl.Load(cmd.ExecuteReader());
}
如果不是,那么你可以这样做:
Excel.Application xl = new Excel.Application();
var wb = xl.Workbooks.Open(path);
Excel.Worksheet ws = (Excel.Worksheet)wb.Worksheets["Engineering BOM"];
var v = ws.Range["A1:I13000"].Value;
(不确定excel本身是否可以进行如此大的数组分配)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.