PHPExcel 库中的 PhpSpreadsheet 导出函数支持超过26个字段的通用函数

这里是使用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 程序的选项来避免出现科学技术法。具体操作步骤如下:

  1. 打开 Excel 文件,并点击左上角的“文件”选项卡。
  2. 在文件选项卡下拉菜单中选择“选项”,打开 Excel 选项窗口。
  3. 在 Excel 选项窗口中选择“高级”选项。
  4. 在“显示选项卡”下拉菜单中找到“显示数字为科学计数法”选项,将其取消勾选。
  5. 点击“确定”按钮保存修改。

这样就可以避免在导出 Excel 文件时出现科学技术法了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值