这里是使用PHPSpreadsheet库实现的导出函数,同样支持超过26个字段的通用函数:
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
use PhpOffice\PhpSpreadsheet\Style\Alignment;
use PhpOffice\PhpSpreadsheet\Style\Border;
function exportExcel($filename, $header, $data)
{
// 实例化Spreadsheet类
$spreadsheet = new Spreadsheet();
$worksheet = $spreadsheet->getActiveSheet();
// 写入表头
$columnCount = count($header);
for ($i = 0; $i < $columnCount; $i++) {
$column = $this->getColumnIndex($i);
$worksheet->setCellValue($column . '1', $header[$i]);
$worksheet->getStyle($column . '1')->getAlignment()->setHorizontal(Alignment::HORIZONTAL_CENTER);
$worksheet->getStyle($column . '1')->getFont()->setBold(true);
$worksheet->getStyle($column . '1')->getBorders()->getAllBorders()->setBorderStyle(Border::BORDER_THIN);
}
// 循环写入数据到表格中
$rowIndex = 2;
foreach ($data as $row) {
$columnIndex = 0;
foreach ($row as $cell) {
$column = $this->getColumnIndex($columnIndex);
$worksheet->setCellValue($column . $rowIndex, $cell);
$worksheet->getStyle($column . $rowIndex)->getAlignment()->setHorizontal(Alignment::HORIZONTAL_CENTER);
$worksheet->getStyle($column . $rowIndex)->getBorders()->getAllBorders()->setBorderStyle(Border::BORDER_THIN);
$columnIndex ++;
}
$rowIndex ++;
}
// 设置响应的Content-Type和Content-Disposition
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header(sprintf('Content-Disposition: attachment;filename="%s.xlsx"', $filename));
// 使用PhpSpreadsheet库生成和输出Excel文件
$writer = new Xlsx($spreadsheet);
$writer->save('php://output');
exit;
}
function getColumnIndex($index)
{
if ($index >= 0 && $index < 26) {
// 如果是 A 到 Z 之间的列,直接返回对应的字母
return chr(65 + $index);
} else {
// 针对 AA、AB、AC ... ZZ 这样的列,使用类似递归的方式计算出对应的字母组合
$result = '';
while ($index >= 26) {
$result .= chr(65 + ($index % 26));
$index = intval($index / 26) - 1;
}
$result .= chr(65 + $index);
return strrev($result); // 需要反转列名字母组合
}
}
使用PHPSpreadsheet库导出excel文件需要先实例化一个Spreadsheet对象,然后将数据写入该对象中,并使用Writer类的save方法输出到php://output。本函数也同样使用了递归计算列名字母组合的方式实现了超过26个字段的支持。
科学计数法出现的原因是 Excel 默认将大于等于 10 的数字按照科学计数法来显示,例如 1000000 默认显示为 1E+06。这种情况的原因是 Excel 对单元格的格式进行了自动处理。
如果你想要避免出现科学计数法,可以在导出 Excel 文件之前给数据进行格式化处理。例如,在处理数据时使用 sprintf 函数将数字转换为字符串,并使用 %d、%f 或 %s 等格式字符来保留其原本的状态。
以下是在导出 Excel 文件之前对数据进行格式化处理的代码示例:
// 假设有如下数据需要导出到Excel表格中
$header = array('姓名', '年龄', '性别', '电话');
$data = array(
array('张三', 20, '男', '18812345678'),
array('李四', 22, '女', '18823456789'),
array('王五', 25, '男', '18834567890')
);
// 将数据格式化为字符串类型
foreach ($data as &$row) {
foreach ($row as &$cell) {
if (is_numeric($cell)) {
$cell = sprintf("%s", $cell);
}
}
}
// 调用工具类的export方法导出Excel文件
ExcelExportTool::export('export_data', $header, $data);
在上面的代码中,首先遍历了导出的数据并对每个单元格进行了格式化,判断单元格是否为数字,如果是数字则使用 sprintf 函数将其转换为字符串类型。这样导出的 Excel 文件就不会出现科学计数法了。
如果在导出 Excel 文件之前进行了格式转换或者设置单元格形式为数字格式,并且导出的 Excel 文件还是出现科学技术法的情况,可能是 Excel 程序的默认设置问题。
你可以尝试修改 Excel 程序的选项来避免出现科学技术法。具体操作步骤如下:
这样就可以避免在导出 Excel 文件时出现科学技术法了。