C# EXCEL导入 混合列文字为空,找不到可安装的 ISAM的解决办法

C# EXCEL导入 混合列文字为空,找不到可安装的 ISAM的解决办法 
使用C#导入 Excel数据到 DataTable,如果连接串中只写 Excel 8.0,则正常的字符列,数值列都没有问题,但对于既有数字也有字符的混合列,则读出为空。 
  后来从网上查到加入IMEX=1 就可将混合型转换为文本,就是连接串为Excel 8.0;IMEX=1,但这有出现 “找不到可安装的 ISAM”。 
  后来在其两边加上单引号' 就可解决。也就是 'Excel 8.0;IMEX=1' 
  EXCEL 默认若前8行都没有出现文本,那么就认为这一列的所有值都是数字,可以在注册表下面语句处修改为默认值,比如500,但尽量将字符行向前。 
  HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Jet\4.0\Engines\Excel 
最后完整的函数如下: 
public static System.Data.DataTable CallExcel(string FilePath, string sheetName) 

OleDbConnection con = new OleDbConnection('Provider=Microsoft.Jet.OLEDB.4.0;Data Source=' + FilePath + ';Extended Properties='Excel 8.0;HDR=YES;IMEX=1''); 
con.Open(); 
string sql = 'select * from [' + sheetName + '$]';//[Sheet1$]';选择第一个数据SHEET 
//OleDbCommand command = new OleDbCommand(sql, con); 
//OleDbDataReader reader = command.ExecuteReader(); 
//if (reader.Read()) 
//{ 
// reader[0].ToString();//直接读出数据 
//} 
OleDbDataAdapter adapter = new OleDbDataAdapter(sql, con); 
System.Data.DataTable dt = new System.Data.DataTable(); 
adapter.Fill(dt); 
//reader.Close(); 
//command.Dispose(); 
con.Close(); 
con.Dispose(); 
return dt; 
}

转载于:https://www.cnblogs.com/IcefishBingqing/p/3721450.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值