dongmin1166 2018-12-10 11:19
浏览 32
已采纳

fgetcsv错误地解释数字[关闭]

I have a problem when I read csv files that contain values like 886468000000, it gets parsed as 8,86468E+11, which is a huge problem for my app, because I need to parse and retain the number in original form.

I google around the documentation and found nothing, I also tried retypging the exponential string representation as float during parsing , but that does not work either, it returns 8, which is obviously incorrect.

  • 写回答

1条回答 默认 最新

  • duanniedang3946 2018-12-10 13:40
    关注

    After testing with PHP 7.2.8 x86 and x64 below are my observations.

    The reason that 8,86468E+11 is being converted to 8 is because of PHP's type-casting behavior when a comma is used instead of a period as the decimal separator. See below:

    echo (float) '8,86468E+11'; // 8 wrong
    
    echo (float) 8,86468E+11; // 88646800000000000 still wrong but getting close
    
    echo (float) '8.86468E+11'; // 886468000000 success!
    
    echo (float) 8.86468E+11; // 886468000000 success!
    

    The primary issue for you is that your decimal separator is a comma instead of a period so to remedy this you will need to make use of str_replace():

    $my_num_from_csv = '8,86468E+11';
    
    $my_num_from_csv = (float) str_replace( ',', '.', $my_num_from_csv );
    
    echo $my_num_from_csv; //886468000000
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 乌班图ip地址配置及远程SSH
  • ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
  • ¥15 PSPICE制作一个加法器
  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 java 的protected权限 ,问题在注释里
  • ¥15 这个是哪里有问题啊?