在C#使用OleDb读取Excel表格数据时,出现外部表不是预期的格式,这个问题也是偶现的
这个问题真的很奇怪,一开始也不知为什么,后面问题出现多了,总结出来,是因为在读取表格数据时需要打开Excel表格,试了很多次都是这样,没有打开表格时就出错,打开表格就正常
代码如下:
/// <summary>
/// 读取excel返回DataTable
/// </summary>
/// <param name="fileName"></param>
/// <param name="sheetName"></param>
/// <returns></returns>
private System.Data.DataTable ExcelToDataTable(string fileName, string sheetName)
{
System.Data.DataTable dt = null;
try
{
string connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + fileName + ";Extended Properties='Excel 8.0;HDR=No;IMEX=1;'";
string selectCommandText = "SELECT * FROM [" + sheetName + "$]";
using (OleDbDataAdapter adapter = new OleDbDataAdapter(selectCommandText, connectionString))
{
dt = new System.Data.DataTable();
adapter.Fill(dt);
return dt;
}
}
catch(Exception ex)
{
MessageBox.Show(ex.ToString());
}
return dt;
}
解决方法:打开需要操作的Excel表格再执行读取操作
20200424
后面发现这是由于公司的加密系统导致的,excel文件解密后即可