天天看点

thinkphp5 导出excel

需要用到phpoffice/phpspreadsheet拓展

在composer.json添加

或者composer require phpoffice/phpspreadsheet

use PhpOffice\PhpSpreadsheet\Spreadsheet;

use PhpOffice\PhpSpreadsheet\Writer\Xlsx;

前台数据传递 :

$('#excel').click(function () {

var rank = $('#rank').val();

var special_rank = $('#special_rank').val();

var start_pv = $('#start_pv').val();

var end_pv = $('#end_pv').val();

var keyword = $('#keyword').val();

var url = $(this).attr('ex_url');

window.open(url+"?rank="+rank+"&special_rank="+special_rank+"&start_pv="+start_pv+"&end_pv="+end_pv+"&keyword="+keyword);

});

后台打印:

$result = 数据;

$spreadsheet = new Spreadsheet();

$sheet = $spreadsheet->getActiveSheet();

$grade = config('grade.grade');

$headLetter = ['A','B','C'];

$headName = ['id','真实姓名','身份证号'];

foreach($headLetter as $k => $v){

$sheet->setCellValue($v.'1', $headName[$k]);、

//自动宽度

$sheet->getColumnDimension($v)->setAutoSize(true);

}

$j = 2;

foreach ($result['data'] as $k => $v) {

$sheet->setCellValue('A' . $j, $v['id'])

->setCellValue('B' . $j, $v['name'])

->setCellValue('C' . $j, $v['id_card'])

$j++;

}

//请求列表数据接口

//$result = sendGetApi('userExcelList');

//设置文件保存的命名、编码、同时开放保存路径的权限

//命名

$fileName = "打印文件" . date("Y-m-d", time()) . ".xlsx";

//编码

header('Content-Type:application/vnd.ms-excel;charset=utf-8');

//告诉浏览器要输出的名称

header("Content-Disposition:attachment;filename=$fileName");

//禁止浏览器缓存

header('Cache-Control:max-age=0');

//生成excel文件

$writer = new Xlsx($spreadsheet);

//彻底开放保存路径

$writer->save('php://output');

exit();

去除科学记数法:在数字字符串前加一个空格使之成为字符串

$objPHPExcel = new PHPExcel();

$objPHPExcel->setActiveSheetIndex(0);

$objPHPExcel->getActiveSheet()->setTitle('Simple');$objPHPExcel->getActiveSheet()->setCellValue('D1', ' ' . 123456789033);