php将身份证号写入excel文件出现科学计数法问题解决

在 PHP 中生成 Excel 文件并处理身份证号时,通常使用 PHPExcel 或其继任者 PhpSpreadsheet 库。身份证号通常是以字符串形式存储的,但在某些情况下,如果身份证号很长(例如,超过 15 位数字),在 Excel 中可能会以科学计数法(如:4.77887E+17)显示。为了避免这种情况,我们需要确保在写入数据时将其作为文本格式处理。

以下是如何使用 PhpSpreadsheet 库来生成 Excel 文件,并确保身份证号不会以科学计数法显示:

  1. 安装 PhpSpreadsheet

    如果你还没有安装 PhpSpreadsheet,可以通过 Composer 安装:

    composer require phpoffice/phpspreadsheet

  2. 创建并保存 Excel 文件

    使用以下 PHP 代码来创建一个 Excel 文件,并确保身份证号作为文本格式写入:

    php 复制代码
    <?php
    
    use PhpOffice\PhpSpreadsheet\Spreadsheet;
    use think\facade\Filesystem;
    use think\facade\Request;
    use PhpOffice\PhpSpreadsheet\IOFactory;
    use PhpOffice\PhpSpreadsheet\Cell\Coordinate;
    
    
    /**
     * 写入excel文件信息  并去除身份证科学计数法
     *
     * @param $data  文件内容
     * @param $title 文件名称前缀
     * @param $savePath 文件存储路径
     * @return string 生成的文件地址
     * @throws \PHPExcel_Exception
     * @throws \PHPExcel_Reader_Exception
     * @throws \PHPExcel_Writer_Exception
     */
    function writerXls($data, $title, $savePath='')
    {
        $objPHPExcel = new Spreadsheet();
        $filename = $title . '-' . date('YmdHis') . '.xls';
        $objPHPExcel->createSheet();
        $objPHPExcel->setActiveSheetIndex(0); //设置第一个工作表为活动工作表
        $objPHPExcel->getActiveSheet()->setTitle('sheet1'); //设置工作表名称
    
        $sheet = $objPHPExcel->getActiveSheet();
    
        foreach ($data as $k => $val) {
            foreach ($val as $i => $v) {
                // 将列索引转换为字母(如 1 -> A, 2 -> B, 3 -> C)
                $colLetter = Coordinate::stringFromColumnIndex($i + 1);
                // 动态生成单元格坐标(如 A1, B2, C3 等)
                $cellCoordinate = $colLetter . ($k + 1);
    
                // 如果是身份证号列,强制存储为文本
                if ($i >= 0) {//都存储为字符串型  此处可设置哪些列设置为字符串类型 判断$i列值即可
                    $sheet->setCellValueExplicit($cellCoordinate, $v, 'str');
                } else {
                    $sheet->setCellValue($cellCoordinate, $v);
                }
    
            }
        }
    
        foreach ($data[0] as $k => $val) {
            in_array($k, array(0, 6)) ? $objPHPExcel->getActiveSheet()->getColumnDimension(chr($k + 65))->setWidth(30) :
                $objPHPExcel->getActiveSheet()->getColumnDimension(chr($k + 65))->setWidth(25);
        }
    
        //输出
        $objWriter = IOFactory::createWriter($objPHPExcel, 'Xls');
    
        if(!$savePath){
             $savePath = '/runtime/storage/upload/error';
        }
        //创建文件夹
        if (!file_exists($savePath)) {
            mkdir($savePath,0777,true);
        }
    
        $objWriter->save($savePath . '/' . $filename);
        unset($objPHPExcel);
    
        return $savePath . '/' . $filename;
    }
    
    ?>
    
    <?php
        // 示例数据
        $data = [
            ['姓名', '身份证号', '手机号'],
            ['张三', '123456789012345678', '13800138000'],
            ['李四', '987654321098765432', '13900139000'],
        ];
        //调用生成xsl文件函数
        $excel_url = writerXls($data, 'id_numbers',  '/download/idcard');
    ?>
  3. 运行代码

    运行上述 PHP 脚本后,你将得到一个名为 id_numbers-20250313******.xls 的 Excel 文件,其中身份证号不会以科学计数法显示。每个身份证号都会被正确识别为文本格式。

通过以上步骤,你可以确保在生成的 Excel 文件中,所有的身份证号都不会被错误地以科学计数法显示。

相关推荐
yenggd2 小时前
centos系统apache支持php配置
centos·php·apache
ytttr87313 小时前
PHP中各种超全局变量使用的过程
开发语言·php
偷心伊普西隆14 小时前
EXCEL VBA 清空Excel工作表(Sheet)的方法
microsoft·excel
名誉寒冰18 小时前
TCP, 三次握手, 四次挥手, 滑动窗口, 快速重传, 拥塞控制, 半连接队列, RST, SYN, ACK
网络·tcp/ip·php
m0_7381207218 小时前
CTFshow系列——PHP特性Web97-100
开发语言·安全·web安全·php·ctfshow
Coding_Doggy19 小时前
苍穹外卖Day12 | Apache POI、导出Excel报表、HttpServletResponse、工作台
excel
~央千澈~21 小时前
【01】针对开源收银系统icepos (宝塔面板) 详细安装教程详细参考-优雅草卓伊凡
开源·php
l1t1 天前
张泽鹏先生手搓的纯ANSI处理UTF-8与美团龙猫调用expat库读取Excel xml对比测试
xml·人工智能·excel·utf8·expat
前端世界2 天前
Python 正则表达式实战:用 Match 对象轻松解析拼接数据流
python·正则表达式·php
苏琢玉2 天前
用 PHP 玩向量数据库:一个从小说网站开始的小尝试
php·composer