刚刚开始做Excel相关的项目,所以遇到的问题不管大小都给记录一下

偶然的机会在添加数据的时候全改成了数字,结果输出的时候全自动变成了科学计数法,这是excel的强大功能,能自动识别数字和字符串,太聪明了反而有些麻烦,就像如果输入身份证(18位数字)的话那就不行了。超过了11位呢,下面查了些资料总结一下解决方案:

方法1:  在往excel中添加数据的时候在数据的前面加单引号或者其他字符、空格等,我的是这个方法解决的

  1. public static string ExportTable(ArrayList data, ArrayList columns)
  2. {
  3.  
  4. ArrayList columnsBottom = getColumnsBottom(columns);
  5.  
  6. ArrayList columnsTable = getColumnsTable(columns);
  7.  
  8. StringBuilder sb = new StringBuilder();
  9. //data = ds.DataSetName + "\n";
  10.  
  11. //data += tb.TableName + "\n";
  12. sb.AppendLine("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\">");
  13. sb.AppendLine("<table cellspacing=\"0\" cellpadding=\"5\" rules=\"all\" border=\"1\">");
  14. //写出列名
  15.  
  16. ; i < columnsTable.Count; i++)
  17. {
  18. ArrayList columnsRow = (ArrayList)columnsTable[i];
  19. sb.AppendLine("<tr style=\"font-weight: bold; white-space: nowrap;\">");
  20. foreach (Hashtable column in columnsRow)
  21. {
  22. sb.AppendLine("<td colspan=" + column["colspan"] + " rowspan=" + column["rowspan"] + ">" + column["header"] + "</td>");
  23. }
  24. sb.AppendLine("</tr>");
  25. }
  26. //写出数据
  27.  
  28. ;
  29. foreach (Hashtable row in data)
  30. {
  31. sb.Append("<tr>");
  32. foreach (Hashtable column in columnsBottom)
  33. {
  34. Object value;
  35. if (column["field"] != null)
  36. {
  37. value = row[column["field"]];
  38. }
  39. else
  40. {
  41. value = "";
  42. }
  43. ;
  44. if(Convert.ToString(column["field"]) == "Order_Code")
  45. {
  46. sb.AppendLine("<td>" + value + "&nbap;</td>");
  47. }else
  48. {
  49. sb.AppendLine("<td >" + value + "</td>");
  50. }
  51. }
  52. sb.AppendLine("</tr>");
  53. count++;
  54. }
  55. sb.AppendLine("</table>");
  56.  
  57. return sb.ToString();
  58. }

方法2:在样式中添加样式::<td style=”vnd.ms-excel.numberformat:@”>

  1. public static string ExportTable(ArrayList data, ArrayList columns)
  2. {
  3.  
  4. ArrayList columnsBottom = getColumnsBottom(columns);
  5.  
  6. ArrayList columnsTable = getColumnsTable(columns);
  7.  
  8. StringBuilder sb = new StringBuilder();
  9. //data = ds.DataSetName + "\n";
  10.  
  11. //data += tb.TableName + "\n";
  12. sb.AppendLine("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\">");
  13. sb.AppendLine("<table cellspacing=\"0\" cellpadding=\"5\" rules=\"all\" border=\"1\">");
  14. //写出列名
  15.  
  16. ; i < columnsTable.Count; i++)
  17. {
  18. ArrayList columnsRow = (ArrayList)columnsTable[i];
  19. sb.AppendLine("<tr style=\"font-weight: bold; white-space: nowrap;\">");
  20. foreach (Hashtable column in columnsRow)
  21. {
  22. sb.AppendLine("<td colspan=" + column["colspan"] + " rowspan=" + column["rowspan"] + ">" + column["header"] + "</td>");
  23. }
  24. sb.AppendLine("</tr>");
  25. }
  26. //写出数据
  27.  
  28. ;
  29. foreach (Hashtable row in data)
  30. {
  31. sb.Append("<tr>");
  32. foreach (Hashtable column in columnsBottom)
  33. {
  34. Object value;
  35. if (column["field"] != null)
  36. {
  37. value = row[column["field"]];
  38. }
  39. else
  40. {
  41. value = "";
  42. }
  43. ;
  44. if(Convert.ToString(column["field"]) == "Order_Code")
  45. {
  46. sb.AppendLine("<td style=\"vnd.ms-excel.numberformat:@\">" + value + "</td>");
  47. }else
  48. {
  49. sb.AppendLine("<td >" + value + "</td>");
  50. }
  51. }
  52. sb.AppendLine("</tr>");
  53. count++;
  54. }
  55. sb.AppendLine("</table>");
  56.  
  57. return sb.ToString();
  58. }

方法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导出Excel/Csv文本格式数据的更多相关文章

  1. asp.net导出Excel 按照预定格式,以及解决导出乱码

    protected void ToExcel() { //新建一个Gridview,原因:避免当前窗口GridView外层没有直接跟form标签,从而避免“gridview1未包含在run='serv ...

  2. [转] Asp.Net 导出 Excel 数据的9种方案

    湛刚 de BLOG 原文地址 Asp.Net 导出 Excel 数据的9种方案 简介 Excel 的强大之处在于它不仅仅只能打开Excel格式的文档,它还能打开CSV格式.Tab格式.website ...

  3. asp.net导出excel并弹出保存提示框

    asp.net导出excel并弹出保存提示框 2013-07-12 | 阅:1  转:78   |  分享  腾讯空间 人人网 开心网 新浪微博 腾讯微博 搜狐空间 推荐给朋友 举报          ...

  4. Asp.net导出Excel续章(自定义合并单元格,非Office组件)

    结合上次写的导出Excel方法,这次上头要求我将列头进行一下合并 以前的效果: 改进后的效果: 在上篇文章中写到了Excel的导出方法,这次为了避免在生产环境中使用Office组件,服务器各种权限配置 ...

  5. asp.net导出excel示例代码

    asp.net导出excel的简单方法. excel的操作,最常用的就是导出和导入. 本例使用NPOI实现. 代码:/// <summary> );             ;       ...

  6. ASP.NET导出EXCEL类

    最新ASP.NET导出EXCEL类 说明:可以导出ASP.NET页面和DATAGRID(WebControl)数据,可以导出表单头 using System;using System.Data;usi ...

  7. Python生成文本格式的excel\xlwt生成文本格式的excel\Python设置excel单元格格式为文本\Python excel xlwt 文本格式

    Python生成文本格式的excel\xlwt生成文本格式的excel\Python设置excel单元格格式为文本\Python excel xlwt 文本格式 解决: xlwt 中设置单元格样式主要 ...

  8. Excel表格文本格式的数字和数字格式如何批量转换

    Excel表格文本格式的数字和数字格式如何批量转换 在使用Excel表格对数据求和时,只能对单元格内常规格式的数据进行计算,而不能对单元格中的文本格式的数据进行计算,特点就是在单元格的左上角有一个绿色 ...

  9. .net解决数据导出excel时的格式问题

    在项目中一般都需要将报表数据导出到EXCEL中,但经常出现导出长串数据(如身份证)到EXCEL中后显示为科学计数法的格式,或者报表中显示为001的数据导出到Excel后成了1的格式. 下面简单介绍一下 ...

随机推荐

  1. Leetcode题解(十二)

    33.Search in Rotated Sorted Array 题目 这道题目如果没有其他要求,直接遍历一遍就可以知道答案,但是,题目给出了是排序了数组,但是数组有可能经过了旋转得到,其解题思路仍 ...

  2. HDU 6092 Rikka with Subset

    Rikka with Subset Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others ...

  3. Mr. Frog’s Game

    Mr. Frog’s Game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)T ...

  4. Linq Take和Skip详解

    Take()方法的作用就是:从查询结果中提取前n个结果. Skip()方法正好是Take()方法的反面,它可以跳过前n个结果,返回剩余的结果. 例如:查找年龄最大的3个人 表Student的数据是 N ...

  5. Javascript下IE与Firefox下的差异兼容写法总结

    http://www.jb51.net/article/23923.htm     总结一部分IE和Firefox的javascript差异写法,对于像书写多浏览器兼容性更好的代码,可以参考下.   ...

  6. return flase 作用

    调用return false的时候,他实际上做了三件事   event.preventDefault();     禁止默认行为   event.stopPropagation();   阻止冒泡   ...

  7. ⑾bootstrap组件 徽章 大屏 页头 基础案例

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. javaweb部署多个项目(复制的项目)

    最近需要在一台服务器部署两个已经编译完了的javaweb项目,但是因为项目名一样,仅修改文件夹的名字无法实现两个项目共存,最后只能考虑采用部署多个tomcat服务器的方法来实现.搜索后终于找到个好方法 ...

  9. 30.Linux-RTC驱动分析及使用

    linux中的rtc驱动位于drivers/rtc下,里面包含了许多开发平台的RTC驱动,我们这里是以S3C24xx为主,所以它的RTC驱动为rtc-s3c.c 1.进入./drivers/rtc/r ...

  10. java.io.File类操作

    一.java.io.File类 String path="E:/222/aaa";//路径 String path1="aaa.txt"; File file= ...