1.下載PHPExcel
安裝命令:composer require phpoffice/phpexcel
2.以thinkphp5.1為例,後臺程式碼
<?
/**
* 匯出資料到excel表格
* @param $expTitle excel檔案的檔名
* @param $expCellName excel的列名
* @param $expTableData excel的內容
*/
function exportExcel($expTitle, $expCellName, $expTableData)
{
include_once EXTEND_PATH . 'PHPExcel/Classes/PHPExcel.php'; //方法二
$xlsTitle = iconv('utf-8', 'gb2312', $expTitle); //檔名稱
$fileName = $expTitle . date('_YmdHis'); //or $xlsTitle 檔名稱可根據自己情況設定
$cellNum = count($expCellName);
$dataNum = count($expTableData);
// $objPHPExcel = new PHPExcel();//方法一
$objPHPExcel = new \PHPExcel(); //方法二
$cellName = array('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'AA', 'AB', 'AC', 'AD', 'AE', 'AF', 'AG', 'AH', 'AI', 'AJ', 'AK', 'AL', 'AM', 'AN', 'AO', 'AP', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AV', 'AW', 'AX', 'AY', 'AZ');
$objPHPExcel->getActiveSheet(0)->mergeCells('A1:' . $cellName[$cellNum - 1] . '1'); //合併單元格
$objPHPExcel->setActiveSheetIndex(0)->setCellValue('A1', $expTitle . ' Export time:' . date('Y-m-d H:i:s'));
for ($i = 0; $i < $cellNum; $i++) {
$objPHPExcel->setActiveSheetIndex(0)->setCellValue($cellName[$i] . '2', $expCellName[$i][1]);
}
// Miscellaneous glyphs, UTF-8
for ($i = 0; $i < $dataNum; $i++) {
for ($j = 0; $j < $cellNum; $j++) {
$objPHPExcel->getActiveSheet(0)->setCellValue($cellName[$j] . ($i + 3), $expTableData[$i][$expCellName[$j][0]]);
}
}
ob_end_clean(); //這一步非常關鍵,用來清除緩衝區防止匯出的excel亂碼
header('pragma:public');
header('Content-type:application/vnd.ms-excel;charset=utf-8;name="' . $xlsTitle . '.xls"');
header("Content-Disposition:attachment;filename=$fileName.xls"); //"xls"參考下一條備註
$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007'); //"Excel2007"生成2007版本的xlsx,"Excel5"生成2003版本的xls
// ajax方法
ob_start();
$objWriter->save("php://output");
$xlsData = ob_get_contents();
ob_end_clean();
return ['filename' => $fileName, 'file' => "data:application/vnd.ms-excel;base64," . base64_encode($xlsData)];
// a連結跳轉
// $objWriter->save('php://output');
exit;
}
public function exportUser(){
$request = request();
$search = $request->param();
// 如果存在使用者等級 使用者查詢條件等於使用者查詢引數
if(isset($search['grade']) && $search['grade']!=""){
$where = ["grade"=>["eq",$search["grade"]]];
}else{
$where = ["grade"=>["in","1,2"]];
}
// 如果存在使用者狀態 使用者狀態查詢條件等於使用者查詢引數
if(isset($search['status']) && $search['status']!=""){
$where = ["status"=>["eq",$search['status']]];
}
//如果存在使用者名稱 使用者名稱查詢條件等於使用者查詢引數
if(isset($search['username']) && $search['username']!=""){
$where = ["username"=>["like","%{$search['username']}%"]];
}
$field = "id,username,headimg,phone,wechat,grade,status";
$user = model("User")->userlist($where,$field);
if($user){
foreach($user as $k => $v){
$user[$k]['status'] = $this->getUserStatusText($v['status']); // 狀態數字轉中文
$user[$k]['grade'] = $this->getUserGradeText($v['grade']);
$user[$k]['total'] = '¥'.$v['total'].'元';
}
$xlsName = '使用者'; // xls的檔名
// xls列名對應的內容轉換 如查詢出來的資料元素名為username,則將username的所有元素放在使用者名稱那一列裡面
$xlsCell = [
['username','使用者名稱'],
['phone','電話號碼'],
['wechat','微信'],
['total','消費總金額'],
['grade','使用者等級'],
['status','使用者狀態'],
];
$res = exportExcel($xlsName,$xlsCell,$user);
return json(['code'=>1,'data'=>$res]);
}else{
return json(['code'=>0,'msg'=>'暫無資料']);
}
}
3.前端程式碼
$("#export").click(function(){
var username = $("input[name='username']").val();
var grade = $("select[name='grade']").val();
var status = $("select[name='status']").val();
$.post("/admin/user/exportuser",{
grade:grade,
status:status,
username:username
},function(res){
if(res.code == 1){
// 建立一個臨時的a標籤放置返回的php檔案路徑
var $a = $("<a>");
$a.attr("href", res.data.file);
$a.attr("download", res.data.filename);
$("body").append($a);
$a[0].click();
$a.remove();
}else{
swal("匯出失敗", "所選條件暫無內容", {
icon: "error",
});
}
});
})
本作品採用《CC 協議》,轉載必須註明作者和本文連結