Asp.net导出Excel或Csv文本格式数据例子
2014-09-20 15:59:31 By: shinyuu
刚刚开始做Excel相关的项目、所以遇到的问题不管大小都给记录一下
偶然的机会在添加数据的时候全改成了数字、结果输出的时候全自动变成了科学计数法
这是excel的强大功能、能自动识别数字和字符串、太聪明了反而有些麻烦
就像如果输入身份证(18位数字)的话那就不行了、超过了11位呢、下面查了些资料总结一下解决方案:
方法1: 在往excel中添加数据的时候在数据的前面加 单引号、我的是这个方法解决的
如:Sheet.Cells[iRow, iCol] ="´"+ ds.Tables[0].Rows[iRow - 3][itm.ID].ToString();
方法2:在样式中添加样式::<td style=”vnd.ms-excel.numberformat:@”>
如:
foreach (DataRow row in tb.Rows){ data += "<tr>"; foreach (DataColumn column in tb.Columns){ if (column.ColumnName.Equals("证件编号") || column.ColumnName.Equals("报名编号")){ data += "<td style="vnd.ms-excel.numberformat:@">" + row[column].ToString() + "</td>"; }else{ data += "<td>" + row[column].ToString() + "</td>"; } } }
方法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是打开的只读连接、所以要正确读取、只能使用只读的方式
若资源对你有帮助、浏览后有很大收获、不妨小额打赏我一下、你的鼓励是维持我不断写博客最大动力
想获取DD博客最新代码、你可以扫描下方的二维码、关注DD博客微信公众号(ddblogs)
或者你也可以关注我的新浪微博、了解DD博客的最新动态:DD博客官方微博(dwtedx的微博)
如对资源有任何疑问或觉得仍然有很大的改善空间、可以对该博文进行评论、希望不吝赐教
为保证及时回复、可以使用博客留言板给我留言: DD博客留言板(dwtedx的留言板)
感谢你的访问、祝你生活愉快、工作顺心、欢迎常来逛逛