您现在的位置是:网站首页> 编程资料编程资料
Asp.net导出Excel/Csv文本格式数据的方法_实用技巧_
2023-05-24
447人已围观
简介 Asp.net导出Excel/Csv文本格式数据的方法_实用技巧_
刚刚开始做Excel相关的项目,所以遇到的问题不管大小都给记录一下
偶然的机会在添加数据的时候全改成了数字,结果输出的时候全自动变成了科学计数法,这是excel的强大功能,能自动识别数字和字符串,太聪明了反而有些麻烦,就像如果输入身份证(18位数字)的话那就不行了。超过了11位呢,下面查了些资料总结一下解决方案:
方法1: 在往excel中添加数据的时候在数据的前面加 单引号,我的是这个方法解决的
如:Sheet.Cells[iRow, iCol] ="'"+ ds.Tables[0].Rows[iRow - 3][itm.ID].ToString();
方法2:在样式中添加样式::
如:
foreach (DataRow row in tb.Rows){data += "
方法3:
ADO.NET读Excel时,会根据该列的前n行数据(n个数来自注册表HKEY_LOCAL_MACHINE/Software/Microsoft/Jet/4.0/Engines/Excel/TypeGuessRows),根据这几行数据的内容来判断该列的类型,这个类型跟Excel中该列的类型无关(文本类型应该是数据前面有一个')。如果这n行中的数据有文本有数字,也就是混合类型,则根据HKEY_LOCAL_MACHINE/Software/Microsoft/Jet/4.0/Engines/Excel/ImportMixedType来取值。如果ImportMixedType值为Text,则该列为文本;如果值为Majority Type,则取数据多的类型。
为了能把有文本有数字的列正确读出,我们需要把注册表中ImportMixedType项设置为text,TypeGuessRows设置为0(表示要读取所有数据再来判断是否是混合类型)
另外需注意,IMEX的取值会影响是否使用注册表中ImportMixedType和MAXSCANROWS这两项,如果IMEX=1,则使用,如果为0或者2,则不使用。而IMEX=1是打开的只读连接,所以要正确读取,只能使用只读的方式。
相关内容
- ASP.NET实现单点登陆(SSO)适用于多种情况_实用技巧_
- asp.net后台如何动态添加JS文件和css文件的引用_实用技巧_
- asp.net(C#)禁止缓存文件不让文件缓存到客户端_实用技巧_
- 使用SNK密钥文件保护你的DLL和代码不被反编译教程_实用技巧_
- ASP.NET实现伪静态网页方法小结_实用技巧_
- .net生成缩略图及水印图片时出现GDI+中发生一般性错误解决方法_实用技巧_
- ASP.Net巧用窗体母版页实例_实用技巧_
- .NET事件监听机制的局限与扩展分析_实用技巧_
- ASP.NET MVC+EF框架+EasyUI实现权限管系列_实用技巧_
- 浅谈ASP.NET MVC应用程序的安全性_实用技巧_
点击排行
本栏推荐
