日期:2014-05-17  浏览次数:20356 次

.net 读取Execl时某一列没有读取到数据
如题!

在Execl里面是有值的;

读取后存放在DataTable里面时就没有了!

各位大虾帮忙解决下!!!

------解决方案--------------------
给你个方法
/// <summary>
/// 读取excel文件返回dataset
/// </summary>
/// <param name="filePath">文件地址</param>
/// <param name="sheetName">sheet名</param>
/// <returns></returns>
public static DataSet ImportExcelToDataSet(string filePath, string sheetName)
{
OleDbConnection strConnection = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + ";Extended Properties='Excel 12.0;HDR=Yes;IMEX=1';");
string strSelect = "select * from [" + sheetName + "$]";
DataSet ds = new DataSet();
try
{
strConnection.Open();
OleDbDataAdapter oleDA = new OleDbDataAdapter(strSelect, strConnection);
oleDA.Fill(ds);
strConnection.Close();
return ds;
}
catch (Exception ex)
{
throw;
}
finally
{
if (strConnection.State == ConnectionState.Open)
{
strConnection.Close();
}
}
}
------解决方案--------------------
在使用 ADO.NET 导出 Excel 文件时,设置 IMEX=1 仍不能导出所有数据的解决办法

今天遇到一个问题,在使用 ADO.NET 导出 Excel 文件时,连接字符串里面已经设置了 IMEX=1,仍有部分数据不能导出,经过研究,需要在注册表中进行设置 TypeGuessRows 的配置,默认情况下,驱动程序会扫描前 8 行数据,来对数据类型进行采样。设置为 0 ,将对列的所有行进行扫描,如果前八行采样数据都是数值类型的话,设置 IMEX = 1 也不会将剩下的行的默认数据类型转换为文本,它将保留数值类型,也就是把整个列当成数字类型对待。 因此,要想得到完整的数据,需要修改注册表的设置 TypeGuessRows 为 0。TypeGuessRows 在注册表的位置:

[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Jet\4.0\Engines\Excel]

Windows 7等 64 系统:
[HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Jet\4.0\Engines\Excel]

IMEX 的可能设置是:

0 Export 模式
1 Import 模式
2 Linked 模式(full update capabilities)

设置 TypeGuessRows 为 0 将会导致性能的下降。IMEX=1 数据内容也能出现不正常的现象,比如长数字可能会出现科学计数法的格式显示。比较好的做法是导出前,对所有单元格进行处理,在单元格内容前面加 '。