PHP生成csv文件时,如果数字的第一位为0的话,显示时则不会显示第一个0
可以在php中做特殊处理,使得生成的csv在显示时能显示出第一个0
有两种方法可以实现:
1、给数字加上引号,并且在引号前面再加上个等号,如数字0555,,则生成时为="0555"
2、在数字前面加上制表符,如是数字0555,则生成时为\t0555
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | $arr = array ( array ( '111' , 2222, '0555' ), array ( '222' , 3333, '0666' ) ); $fp = fopen ( 't.csv' , 'w' ); foreach ( $arr as $row ) { fputcsv ( $fp , array_map ( 'h' , $row )); } fclose( $fp ); function h( $v ) { if (( $v {0} == '0' ) && is_numeric ( $v )) { $v = '="' . $v . '"' ; //第一种方式 //$v = "\t{$v}"; //第二种方式 } return $v ; } |