解决使用phpspreadsheet导出Xlsx纯数字字符串变成科学计数法的问题

本文介绍了在使用phpspreadsheet导出Excel时遇到的纯数字字符串被转换为科学计数法的问题。通过分析源码,发现dataTypeForValue方法导致类型判断错误。为解决此问题,文章提供了一个自定义类,继承DefaultValueBinder并重写相关方法,以确保数值以预期的格式导出。

Demo:

<?php
$spreadsheet = new \PhpOffice\PhpSpreadsheet\Spreadsheet();
$spreadsheet->getActiveSheet()->setCellValue('A1', '900473179110024');
$xlsx = new \PhpOffice\PhpSpreadsheet\Writer\Xlsx($spreadsheet);
$xlsx->save('test.xlsx');

执行后打开生成的Excel如下图,在A1格子里本该出现的值是900473179110024,但是实际上输出的excel却变成了科学计数法,将它变成字符后也是900473179110020,与期待值并不相同
图1

解决方案:
在经过一步步追踪后发现,phpspreadsheet在记录这个值之前做了类型判断,以下截取部分源码做分析:

<?php

namespace PhpOffice\PhpSpreadsheet\Cell;

use DateTimeInterface;
use PhpOffice\PhpSpreadsheet\RichText\RichText;
use PhpOffice\PhpSpreadsheet\Shared\StringHelper;

class DefaultValueBinder implements IValueBinder
{
    public function bindValue(Cell $cell, $value)
    {
        ...
        // Set value explicit
        $cell->setValueExplicit($value, static::dataTypeForValue($value))
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值