在使用 ADO.NET 导出 Excel 文件时,设置 IMEX=1 仍不能导出所有数据的解决办法
2011-03-08 08:48
926 查看
在使用 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 数据内容也能出现不正常的现象,比如长数字可能会出现科学计数法的格式显示。比较好的做法是导出前,对所有单元格进行处理,在单元格内容前面加 '。
[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 数据内容也能出现不正常的现象,比如长数字可能会出现科学计数法的格式显示。比较好的做法是导出前,对所有单元格进行处理,在单元格内容前面加 '。
相关文章推荐
- 在使用 ADO.NET 导出 Excel 文件时,设置 IMEX=1 仍不能导出所有数据的解决办法
- 在使用 ADO.NET 导出 Excel 文件时,设置 IMEX=1 仍不能导出所有数据的解决办法
- 使用UltraWebGridExcelExporter控件导出分页Grid所有数据的简单解决办法
- asp.net 生成导出word表单 ,导出excel; dataTable生成xls文件,返回前台下载;asp.net启动excel错误 80070005;excel-xls columnName 不能改变; 读写excel的开源利器NPOI; 设置excel Cell的数据类型;
- Asp.Net MVC 使用FileResult导出Excel数据文件
- 转载:在部署时使用Excel .NET运行库导出Excel遇到问题及解决办法
- 使用ADO.net将数据导出到Excel并提供下载
- (解决办法)ASP.NET导出Excel,打开时提示“您尝试打开文件'XXX.xls'的格式与文件扩展名指定文件不一致
- 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致的解决办法
- 使用jxl导出大数据量EXCEL时内存溢出的解决办法
- Ado.Net操作Excel文件数据常见问题及解决
- (解决办法)ASP.NET导出Excel,打开时提示“您尝试打开文件'XXX.xls'的格式与文件扩展名指定文件不一致
- Asp.Net MVC 使用FileResult导出Excel数据文件
- 转载+整理:在部署时使用Excel .NET运行库导出Excel遇到问题及解决办法
- Asp.Net MVC 使用FileResult导出Excel数据文件
- 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致的解决办法
- ASP.NET 导出excel文件出现乱码的解决办法
- 使用ADO.net将数据导出到Excel并提供下载
- Asp.Net MVC 使用FileResult导出Excel数据文件
- 使用ADO.net将数据导出到Excel并提供下载