• php导出数据到csv文件


    $count = M('revieworder')->where($map)->count();
    set_time_limit(0);
    ini_set('memory_limit', '256M');
    $filename = '预约' . time() . '.csv';
    header("Content-type:text/csv");
    header('Content-Disposition: attachment;filename="' . $filename . '"');
    header('Cache-Control: max-age=0');
    // 打开PHP文件句柄,php://output 表示直接输出到浏览器
    $fp = fopen('php://output', 'a');
    $head = array('编号','姓名','手机号','预约日期','***','区域','短信发送','备注','申请时间');
    foreach ($head as $i => $v) {
    // CSV的Excel支持GBK编码,一定要转换,否则乱码
    $head[$i] = iconv('utf-8', 'gbk', $v);
    }
    // 将数据通过fputcsv写到文件句柄
    fputcsv($fp, $head);
    // 从数据库中获取数据,为了节省内存,不要把数据一次性读到内存,从句柄中一行一行读即可
    $limit = 10000;
    for ($i = 0; $i < $count; $i = $i + $limit) {
    $list = M('revieworder')->where($map)->order('createtime desc')->limit($i, $limit)->select();
    foreach ($list as $k => $val) {
    $rows[0] = iconv('utf-8', 'gbk', $k + 1);
    $rows[1] = iconv('utf-8', 'gbk', " " . $val['realname']);
    $rows[2] = iconv('utf-8', 'gbk', $val['mobile']);
    $rows[3] = iconv('utf-8', 'gbk', " " . getSubstr($val['orderdate'],0,10).' '.$val['amorpm']);
    $rows[4] = iconv('utf-8', 'gbk', $val['subject']);
    $rows[5] = iconv('utf-8', 'gbk', $val['area']);
    $rows[6] = iconv('utf-8', 'gbk', $val['issend'] == '1'?'已发送':'未发送');
    $rows[7] = iconv('utf-8', 'gbk', $val['note']);
    $rows[8] = iconv('utf-8', 'gbk', time_format($val['createtime']));
    fputcsv($fp, $rows);
    unset($rows);
    }
    ob_flush();
    flush(); //刷新buffer
    }
    exit;
  • 相关阅读:
    Qt判断文件夹是否存在并新建文件夹
    QFileDialog的使用
    C++11 std::chrono库详解
    disconnected no supported authentication methods available(server sent: publickey)
    connect函数的第5参数Qt::ConnectionType
    在C++ 中检查一个文件是否存在的几种方法
    win10打开便签
    1024. Palindromic Number (25)
    1023. Have Fun with Numbers (20)
    1021. Deepest Root (25)
  • 原文地址:https://www.cnblogs.com/wenxinphp/p/7094559.html
Copyright © 2020-2023  润新知