高效的php导出xls或者csv的方法

  经常会需要从数据库中导出数据到Excel文件,用PHPExcel,确实比较容易实现,但对大量数据的支持很不好,很容易到达PHP内存使用上限。这里的方法是利用fputcsv写CSV文件的方法,直接向浏览器输出Excel文件。

<?php  
// 输出Excel文件头
$docname = iconv('UTF-8', 'GB2312', "用户");
header('Content-Type: application/vnd.ms-excel');  
header('Content-Disposition: attachment;filename="' . $docname . '.csv"');  
header('Cache-Control: max-age=0');  
include './Mysql.class.php';//mysql 操作类  
$db = new mysql();
// 从数据库中获取数据,为了节省内存,不要把数据一次性读到内存,从句柄中一行一行读即可
$sql = 'select id,user_login from users';
$stmt = $db->getAll($sql);

// 打开PHP文件句柄,php://output 表示直接输出到浏览器
$fp = fopen('php://output', 'a');

// 输出Excel列名信息
$head = array("id", "姓名");
foreach ($head as $i => $v) {  
    // CSV的Excel支持GBK编码,一定要转换,否则乱码
    $head[$i] = iconv('utf-8', 'gbk', $v);
}

// 将数据通过fputcsv写到文件句柄
fputcsv($fp, $head);

// 计数器
$cnt = 0;
// 每隔$limit行,刷新一下输出buffer,不要太大,也不要太小
$limit = 100000;

// 逐行取出数据,不浪费内存
$count = count($stmt);
for ($t = 0; $t < $count; $t++) {

    $cnt++;
    if ($limit == $cnt) { //刷新一下输出buffer,防止由于数据过多造成问题
        ob_flush();
        flush();
        $cnt = 0;
    }
    $row = $stmt[$t];
    foreach ($row as $i => $v) {
        $row[$i] = iconv('utf-8', 'gbk', $v);
    }
    fputcsv($fp, $row);
}