欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

PHPExcel导出的长数字被科学计数法转换丢失数据解决

程序员文章站 2022-04-25 11:19:29
...
EXCEL表 F 列为长数字,如 2015072708542427700014133717 导出后会变成 201507270854242770001410000

上网搜解决方案,第一个方案为设置第 F 列为字符串形式,如下

$objPHPExcel = new PHPExcel();

//设置F列(订单号)为文本格式
$objPHPExcel->getActiveSheet()->getStyle('F')->getNumberFormat()
->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_TEXT);
$i=1;
foreach($info as $row){
$asc2 = 65;
foreach($row as $field){
$objPHPExcel->setActiveSheetIndex(0)->setCellValue(chr($asc2++).$i, $field);
}
$i++;

}

结果失败,可能是设置格式的时候出了什么问题。

然后继续搜索,找到第二种方式

// 操作第一个工作表
$objPHPExcel->setActiveSheetIndex(0);
$i=1;
foreach($info as $row){
$asc2 = 65;
foreach($row as $field){
$objPHPExcel->getActiveSheet()->setCellValueExplicit(chr($asc2++).$i, $field, PHPExcel_Cell_DataType::TYPE_STRING);
}
$i++;
}

设置单元格的时候指定这个数据的类型,就成功了。

版权声明:本文为博主原创文章,未经博主允许不得转载。

以上就介绍了PHPExcel导出的长数字被科学计数法转换丢失数据解决,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

PHPExcel导出的长数字被科学计数法转换丢失数据解决

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

相关文章

相关视频