zoukankan      html  css  js  c++  java
  • 解决 PHPExcel 长数字串显示为科学计数[转]

    解决 PHPExcel 长数字串显示为科学计数

    在excel中如果在一个默认的格中输入或复制超长数字字符串,它会显示为科学计算法,例如身份证号码,解决方法是把表格设置文本格式或在输入前加一个单引号。

    使用PHPExcel来生成excel,也会遇到同样的问题,解决方法有三种:
    1、设置单元格为文本

    $objPHPExcel = new PHPExcel();
    $objPHPExcel->setActiveSheetIndex(0);
    $objPHPExcel->getActiveSheet()->setTitle('Simple');
    //设置A3单元格为文本
    $objPHPExcel->getActiveSheet()->getStyle('A3')->getNumberFormat()
    	->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_TEXT);
    //也可以设置整行或整列的style
    /*
    //E 列为文本
    $objPHPExcel->getActiveSheet()->getStyle('E')->getNumberFormat()
    	->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_TEXT);
    //第三行为文本
    $objPHPExcel->getActiveSheet()->getStyle('3')->getNumberFormat()
    	->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_TEXT);
    */
    更多的格式可以在PHPExcel/Style/NumberFormat.php中找到。注意:上述的设置对长数字字符串还是以文本方式来显示科学计数法的结果,原因可能php在处理大数字时采用的科学计数法。

    2、在设置值的时候显示的指定数据类型

    $objPHPExcel = new PHPExcel();
    $objPHPExcel->setActiveSheetIndex(0);
    $objPHPExcel->getActiveSheet()->setTitle('Simple');
    
    $objPHPExcel->getActiveSheet()->setCellValueExplicit('D1',
                                     123456789033, 
                                     PHPExcel_Cell_DataType::TYPE_STRING);
    

    3、在数字字符串前加一个空格使之成为字符串

    $objPHPExcel = new PHPExcel();
    $objPHPExcel->setActiveSheetIndex(0);
    $objPHPExcel->getActiveSheet()->setTitle('Simple');
    
    $objPHPExcel->getActiveSheet()->setCellValue('D1', ' ' . 123456789033);
    

    推荐使用第二、三种,第一种没有根本解决问题。

    =====================================================================================================

    以上内容为转载,个人补充如下:

    第一种方法中不起作用,现在要这样设置才起作用:

    $objPHPExcel->getActiveSheet()->getStyle('S'.$i)->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_NUMBER);

    但是用这种方法,如果数字长度超过15位,则15为之后的都会变成0,原因如下:

    excel最多支持的数值型数据的长度是15位。当数据长度到过15位时,从第16位开始,后面的数字全部被默认修改为0。

  • 相关阅读:
    Python+Selenium 自动化实现实例Xpath捕捉元素的几种方法
    Python+Selenium 自动化实现实例获取页面元素信息(百度首页)
    Example4_6(用类名调用类方法)
    Example5_2(子类对象的构造方法)
    关键字super
    字符数组中的大小写字母变换/使用对象数组
    参数传值(Example4_7.Example4_8,Example4_9)
    私有变量和私有方法(Example4_15和Example4_16)
    Example4_11(关键字this)
    成员变量(对象共享类变量及常量的用法)Example4_4//Example4_5
  • 原文地址:https://www.cnblogs.com/helloyb/p/4110092.html
Copyright © 2011-2022 走看看