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

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++;
}

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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值