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

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

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

 public static string ExportTable(ArrayList data, ArrayList columns)
        {

            ArrayList columnsBottom = getColumnsBottom(columns);

            ArrayList columnsTable = getColumnsTable(columns);

            StringBuilder sb = new StringBuilder();
            //data = ds.DataSetName + "\n";

            //data += tb.TableName + "\n";
            sb.AppendLine("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\">");
            sb.AppendLine("<table cellspacing=\"0\" cellpadding=\"5\" rules=\"all\" border=\"1\">");
            //写出列名

            ; i < columnsTable.Count; i++)
            {
                ArrayList columnsRow = (ArrayList)columnsTable[i];
                sb.AppendLine("<tr style=\"font-weight: bold; white-space: nowrap;\">");
                foreach (Hashtable column in columnsRow)
                {
                    sb.AppendLine("<td colspan=" + column["colspan"] + " rowspan=" + column["rowspan"] + ">" + column["header"] + "</td>");
                }
                sb.AppendLine("</tr>");
            }
            //写出数据

            ;
            foreach (Hashtable row in data)
            {
                sb.Append("<tr>");
                foreach (Hashtable column in columnsBottom)
                {
                    Object value;
                    if (column["field"] != null)
                    {
                        value = row[column["field"]];
                    }
                    else
                    {
                        value = "";
                    }
                    ;
                    if(Convert.ToString(column["field"]) == "Order_Code")
                    {
                        sb.AppendLine("<td>" + value + "&nbap;</td>");
                    }else
                    {
                        sb.AppendLine("<td >" + value + "</td>");
                    }
                }
                sb.AppendLine("</tr>");
                count++;
            }
            sb.AppendLine("</table>");

            return sb.ToString();
        }

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

 public static string ExportTable(ArrayList data, ArrayList columns)
        {

            ArrayList columnsBottom = getColumnsBottom(columns);

            ArrayList columnsTable = getColumnsTable(columns);

            StringBuilder sb = new StringBuilder();
            //data = ds.DataSetName + "\n";

            //data += tb.TableName + "\n";
            sb.AppendLine("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\">");
            sb.AppendLine("<table cellspacing=\"0\" cellpadding=\"5\" rules=\"all\" border=\"1\">");
            //写出列名

            ; i < columnsTable.Count; i++)
            {
                ArrayList columnsRow = (ArrayList)columnsTable[i];
                sb.AppendLine("<tr style=\"font-weight: bold; white-space: nowrap;\">");
                foreach (Hashtable column in columnsRow)
                {
                    sb.AppendLine("<td colspan=" + column["colspan"] + " rowspan=" + column["rowspan"] + ">" + column["header"] + "</td>");
                }
                sb.AppendLine("</tr>");
            }
            //写出数据

            ;
            foreach (Hashtable row in data)
            {
                sb.Append("<tr>");
                foreach (Hashtable column in columnsBottom)
                {
                    Object value;
                    if (column["field"] != null)
                    {
                        value = row[column["field"]];
                    }
                    else
                    {
                        value = "";
                    }
                    ;
                    if(Convert.ToString(column["field"]) == "Order_Code")
                    {
                        sb.AppendLine("<td style=\"vnd.ms-excel.numberformat:@\">" + value + "</td>");
                    }else
                    {
                        sb.AppendLine("<td >" + value + "</td>");
                    }
                }
                sb.AppendLine("</tr>");
                count++;
            }
            sb.AppendLine("</table>");

            return sb.ToString();
        }

方法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是打开的只读连接,所以要正确读取,只能使用只读的方式。

最新文章

  1. SSD Trim Support -- 保护 SSD
  2. Python模块:struct
  3. [iOS微博项目 - 3.2] - 发送微博
  4. 【POJ3237】Tree(树链剖分+线段树)
  5. Retinex processing for automatic image enhancement 翻译
  6. LED音乐频谱之输出数据处理
  7. 抓取QQ空间相册
  8. 201521123060 《Java程序设计》第9周学习总结
  9. IRP的同步
  10. 云计算之路-阿里云上:博客web服务器轮番CPU 100%
  11. 易错点---所有的字符都自带bool值
  12. Oracle查看表实际占用空间和实际行数
  13. Oracle 统计信息收集
  14. 浏览器解析JavaScript原理
  15. P2690 接苹果(暴力搜索+记忆化)
  16. JAVA图书管理系统汇总共27个
  17. 19、UWP 新特性(Creator Update)
  18. json格式化
  19. 使用CAReplicatorLayer [2]
  20. 网站访问日志User Agent对照表

热门文章

  1. Line belt
  2. python如何将指定路径下的某类型文件,返回一个树形结构体,让前端显示为树形的目录结构
  3. gulp learning note
  4. Visual formatting model 可视化格式模型
  5. CentOS、Ubuntu配置网卡子接口
  6. Problem B: 大整数的加法运算
  7. Cordova cannot add Android failed with exit code ENOENT
  8. 【APP问题定位(三)】adb安装
  9. Lucene搜索引擎例子demo
  10. 采用Vue2.0开发的分页js组件