ASP.NET导出EXCEL 数字转文本格式

刚刚开始做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是打开的只读连接、所以要正确读取、只能使用只读的方式

 

文章转自:http://dwtedx.com/itshare_226.html

转载于:https://www.cnblogs.com/qing-xuanlvyee/articles/4521822.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值