当前位置: 移动技术网 > IT编程>开发语言>.net > Asp.net导出Excel/Csv文本格式数据

Asp.net导出Excel/Csv文本格式数据

2019年04月19日  | 移动技术网IT编程  | 我要评论

h55155,我要闹绯闻,敌营十八年碧血丹心

偶然的机会在添加数据的时候全改成了数字,结果输出的时候全自动变成了科学计数法,这是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是打开的只读连接,所以要正确读取,只能使用只读的方式。

 

作者:kaifa123

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网