PHP导出Excel:精准控制列宽,确保数据对齐
本文探讨如何使用PHP导出Excel文件,并精确控制列宽,确保“支付宝账号”、“姓名”、“打款金额”分别准确占据A、B、C列。 原生PHP的fputcsv函数在列宽控制方面能力有限,因此我们将借助PHPExcel库来实现这一目标。
问题:数据列不对齐
以下代码片段使用原生PHP导出Excel,但无法保证列宽和列位置:
set_time_limit(0); ob_end_clean(); header("content-type: application/vnd.ms-excel"); header('content-disposition: attachment; filename="文章信息统计'.date('ymdhis').'.xls"'); $fp = fopen('php://output', 'w'); fwrite($fp, chr(0xef).chr(0xbb).chr(0xbf)); $title = array('支付宝账号','姓名','打款金额'); fputcsv($fp, $title, "\t"); $body = array(); foreach($list as $key=>$val){ $body['alipay_acount'] = $val['alipay_acount']; $body['alipay_real_name'] = $val['alipay_real_name']; $body['money'] = $val['total_check_che']; fputcsv($fp, $body, "\t"); } fclose($fp);
解决方案:使用PHPExcel库
PHPExcel库提供了更精细的Excel文件操作能力。以下代码演示如何使用PHPExcel设置列宽,确保数据准确落入A、B、C列:
require_once 'Classes/PHPExcel.php'; // 引入PHPExcel库 $objPHPExcel = new PHPExcel(); $sheet = $objPHPExcel->getActiveSheet(); // 设置表头 $sheet->setCellValue('A1', '支付宝账号'); $sheet->setCellValue('B1', '姓名'); $sheet->setCellValue('C1', '打款金额'); // 设置数据 $row = 2; foreach ($list as $val) { $sheet->setCellValue('A' . $row, $val['alipay_acount']); $sheet->setCellValue('B' . $row, $val['alipay_real_name']); $sheet->setCellValue('C' . $row, $val['total_check_che']); $row++; } // 设置列宽 $sheet->getColumnDimension('A')->setWidth(20); // 支付宝账号列宽 $sheet->getColumnDimension('B')->setWidth(15); // 姓名列宽 $sheet->getColumnDimension('C')->setWidth(10); // 打款金额列宽 // 保存Excel文件 $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); // Excel5 for .xls $objWriter->save('文章信息统计'.date('ymdhis').'.xls');
此代码首先使用PHPExcel创建Excel文件和工作表,然后设置表头和数据。关键在于getColumnDimension()方法,它允许我们分别设置A、B、C列的宽度,确保数据对齐。最后,代码使用PHPExcel_IOFactory保存Excel文件。 记得安装PHPExcel库并正确配置路径。
通过使用PHPExcel库,我们可以更有效地控制Excel文件的格式,避免数据错位,提升数据导出质量。
以上就是在PHP导出Excel时,如何设置列宽以确保支付宝账号、姓名和打款金额分别占据A、B、C列?的详细内容,更多请关注资源网其它相关文章!
发表评论:
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。