Chinaunix首页 | 论坛 | 博客
  • 博客访问: 162697
  • 博文数量: 89
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 70
  • 用 户 组: 普通用户
  • 注册时间: 2016-06-29 23:10
文章分类

全部博文(89)

文章存档

2016年(89)

我的朋友

分类: Web开发

2016-07-16 22:38:19

php生成csv文件时,如果数字的第一位为0的话,显示时则不会显示第一个0

可以在php中做特殊处理,使得生成的csv在显示时能显示出第一个0

有两种方法可以实现:

1、给数字加上引号,并且在引号前面再加上个等号,如数字0555,,则生成时为="0555"

2、在数字前面加上制表符,如是数字0555,则生成时为\t0555

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

转载自:

阅读(4320) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~