Php 通过数组导出Excel CSV文件

表头数组格式如下:

$header = array(
    0 => "id",
    1 => "用户名称",
    2 => "用户性别",
    3 => "金额"
);

表数据格式如下:

$data = array(

    /* 第一行 */
    0 => array(
         0 => 1,                     // id
         1 => "xiaoming",            // 用户名称
         2 => '男',                  // 用户性别
         3 => 100
    ),

    /* 第二行 */
    0 => array(
         0 => 2,                     // id
         1 => "xiaohong",            // 用户名称
         2 => '女',                  // 用户性别
         3 => 200
    ),

    ...
);

调用函数代码:

function toCsv($filename, $header, $data, $arrayText = array(), $flag = 1) {
    set_time_limit(120000);
    ignore_user_abort(true);
    ini_set('memory_limit', '2048M');

    // 输出Excel文件头,可把user.csv换成你要的文件名
    if (!headers_sent()) {
        header('Content-Type: application/vnd.ms-excel');
        header('Content-Disposition: attachment;filename="' . $filename . '.csv"');
        header('Cache-Control: max-age=0');
    }

    // 打开PHP文件句柄,php://output 表示直接输出到浏览器
    $fp = fopen('php://output', 'a');
    foreach ($header as $i => $v) {
        // CSV的Excel支持GBK编码,一定要转换,否则乱码
        $header[$i] = iconv('utf-8', 'gbk', $v);
    }
    // 将数据通过fputcsv写到文件句柄
    if ($flag == 1) {
        fputcsv($fp, $header);
    }

    // 逐行取出数据,不浪费内存
    if (!empty($data) && is_array($data)) {
        foreach ($data as $row) {
            foreach ($row as $i => $v) {
                $row[$i] = iconv('utf-8', "gbk//IGNORE", $v);
                if (in_array($i, $arrayText)) {
                    $row[$i] = "\t" . $row[$i];
                }
            }
            fputcsv($fp, $row);
        }
    }
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

潘广宇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值