经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » PHP » 查看文章
Laravel 使用 maatwebsite/excel 时长数字出现科学计数法的解决办法
来源:cnblogs  作者:小舟悠悠水中摇  时间:2022/1/17 11:12:06  对本文有异议

在使用 maatwebsite/excel 包导出Excel的时候,有的单元格里会存放手机号等一大串的数字,这一串数字会被Excel软件处理为科学计数法,在后续处理数据的时候会产生不小的麻烦,一个个去调会很麻烦,有幸在度娘上搜到了一个方法,奈何原网站打不开了,所以在这里记录一下这个问题的解决办法。

使用maatwebsite/excel的教程可以参考这篇文章

Laravel 使用 maatwebsite/Excel 3.1 导入导出 Excel

言归正传,首先找到 vendor/maatwebsite/excel/src/DefaultValueBinder.php 文件
打开后的文件内容是这样的:

  1. <?php
  2. namespace Maatwebsite\Excel;
  3. use PhpOffice\PhpSpreadsheet\Cell\Cell;
  4. use PhpOffice\PhpSpreadsheet\Cell\DefaultValueBinder as PhpSpreadsheetDefaultValueBinder;
  5. class DefaultValueBinder extends PhpSpreadsheetDefaultValueBinder
  6. {
  7. /**
  8. * @param Cell $cell Cell to bind value to
  9. * @param mixed $value Value to bind in cell
  10. *
  11. * @return bool
  12. */
  13. public function bindValue(Cell $cell, $value)
  14. {
  15. if (is_array($value)) {
  16. $value = \json_encode($value);
  17. }
  18. return parent::bindValue($cell, $value);
  19. }
  20. }

引入use PhpOffice\PhpSpreadsheet\Cell\DataType类

在bindValue方法里添加

  1. if (strlen($value) > 10) {
  2. $cell->setValueExplicit($value, DataType::TYPE_STRING);
  3. return true;
  4. }

使用PHPstorm的时候会提示This file dose not belong to the project ,选择第一个就好了。

修改后的文件是这样子的:

  1. <?php
  2. namespace Maatwebsite\Excel;
  3. use PhpOffice\PhpSpreadsheet\Cell\Cell;
  4. use PhpOffice\PhpSpreadsheet\Cell\DataType;
  5. use PhpOffice\PhpSpreadsheet\Cell\DefaultValueBinder as PhpSpreadsheetDefaultValueBinder;
  6. class DefaultValueBinder extends PhpSpreadsheetDefaultValueBinder
  7. {
  8. /**
  9. * @param Cell $cell Cell to bind value to
  10. * @param mixed $value Value to bind in cell
  11. *
  12. * @return bool
  13. */
  14. public function bindValue(Cell $cell, $value)
  15. {
  16. if (is_array($value)) {
  17. $value = \json_encode($value);
  18. }
  19. //超过10位的数字转文本格式,防止科学计数法
  20. if (strlen($value) > 10) {
  21. $cell->setValueExplicit($value, DataType::TYPE_STRING);
  22. return true;
  23. }
  24. return parent::bindValue($cell, $value);
  25. }
  26. }

原文链接:http://www.cnblogs.com/iwillrich/p/15746036.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号