欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  php教程

PHP将mysql数据库导出为excel表

程序员文章站 2022-06-12 19:02:10
...
利用php导出mysql数据库为excel表格的方法很多,最简单的就直接使用php fputcsv函数了,还有就是直接输入csv格式也是可以了,要生成excel标准格式我们需使用第三方插件了.

方法一,利用fputcsv,代码如下:

// 输出Excel文件头,可把user.csv换成你要的文件名  
header('Content-Type: application/vnd.ms-excel');  
header('Content-Disposition: attachment;filename="user.csv"');  
header('Cache-Control: max-age=0'); 
 
// 从数据库中获取数据,为了节省内存,不要把数据一次性读到内存,从句柄中一行一行读即可  
$sql = 'select * from tbl where ……';  
$stmt = $db->query($sql); 
 
// 打开PHP文件句柄,php://output 表示直接输出到浏览器  
$fp = fopen('php://output', 'a'); 
 
// 输出Excel列名信息  
$head = array('姓名', '性别', '年龄', 'Email', '电话', '……');  
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; 
 
// 逐行取出数据,不浪费内存  
while ($row = $stmt->fetch(Zend_Db::FETCH_NUM)) { 
//开源代码phprm.com 
$cnt ++;  
if ($limit == $cnt) { //刷新一下输出buffer,防止由于数据过多造成问题  
ob_flush();  
flush();  
$cnt = 0;  
} 
 
foreach ($row as $i => $v) {  
$row[$i] = iconv('utf-8', 'gbk', $v);  
}  
fputcsv($fp, $row);  
}

方法二,直接在浏览器用header输出csv格式的数据,代码如下:

例3, 第二个差不多了, 代码如下:

//搜索
$start_time = strtotime($start_date);
$end_time = strtotime($end_date);
$sql = "select a.*,b.order_amount,b.money_paid from " . $ecs->table('invoice') . " as a " . " left join " . $ecs->table('order_info') . " as b on a.order_id=b.order_s\n" . " where a.add_time >=" . $start_time . " and a.add_time getAll($sql);
if ($temp_list) { //有数据
$Html = '' . chr(13) . chr(10);
$Html.= '
'; //取得符合条件的数组 for ($i = 0; $i '; } $Html.= '
时间: ' . $start_date . '~' . $end_date . '
编号 发票类型 发票抬头 发票内容 订单号 金额 添加日期 收件人 联系方式 地址
' . $temp_i . ' ' . $temp_list[$i][type_name] . ' ' . $temp_list[$i][top] . ' ' . $temp_list[$i][content] . ' ' . $temp_list[$i][order_id] . ' ' . $temp_money . ' ' . $temp_time . ' ' . $temp_list[$i][user_name] . ' ' . $temp_list[$i][mobile] . ' ' . $temp_list[$i][tel] . ' ' . $temp_list[$i][address] . '
'; $Html.= ''; $mime_type = 'application/vnd.ms-excel'; header('Content-Type: ' . $mime_type); header('Content-Disposition: attachment; filename="invoice.xls"'); header('Cache-Control: must-revalidate, post-check=0, pre-check=0'); header('Pragma: public'); echo $Html;

有时excel会自动把数字转换格式, 于是有些手机号码, 身份证之类的就乱了, 因此可以在导出时, 先定义好如下代码: '.$temp_list[$i][order_id].'