博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Asp.net导出Excel/Csv文本格式数据
阅读量:6849 次
发布时间:2019-06-26

本文共 1185 字,大约阅读时间需要 3 分钟。

刚刚开始做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>";elsedata += "<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是打开的只读连接,所以要正确读取,只能使用只读的方式。

转载地址:http://rzrul.baihongyu.com/

你可能感兴趣的文章
java 5.0引入的新特性-枚举
查看>>
vue 项目心得
查看>>
redirect_uri 参数错误
查看>>
Solidedge如何新建参考平面 参考面
查看>>
IE11下javascript报堆栈溢出问题的解决
查看>>
黑马day16 jquery&amp;属性过滤选择器
查看>>
新概念英语(1-49)At the butcher's
查看>>
springMVC新理解
查看>>
【iOS】UIWebView HTML5 扩展
查看>>
Codeforces 460 D. Little Victor and Set
查看>>
spring datasource和mybatis的datasource来源在哪里
查看>>
洛谷2017 5月月赛R1
查看>>
android开发环境搭建教程
查看>>
NAND flash和NOR flash的区别详解
查看>>
IIS Modules Overview
查看>>
数据结构 之 二叉堆(Heap)
查看>>
JNI之—— Eclipse配置C/C++开发环境
查看>>
绘制你的第一个图表(jquery-flot-line-chart)
查看>>
lombok在IntelliJ IDEA下的使用
查看>>
jQuery使用正则判断是否含有非法字符
查看>>