tp8读取mysql导出excel

环境:php8.3, thinkphp8.0, mysql8.0

php 复制代码
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
use PhpOffice\PhpSpreadsheet\Style\Alignment;
use think\facade\Db;
use think\response\Json;

class Index
{
    public function index(): Json
    {
        // 查询 MySQL 数据表数据
        $employees = Db::name('employee')
            ->field('emp_name, emp_sex, emp_phone, create_time')
            ->select()
            ->toArray();

        // 创建 PhpSpreadsheet 对象
        $spreadsheet = new Spreadsheet();
        $sheet = $spreadsheet->getActiveSheet();

        // 设置表头
        $sheet->setCellValue('A1', '姓名');
        $sheet->setCellValue('B1', '性别');
        $sheet->setCellValue('C1', '电话');
        $sheet->setCellValue('D1', '日期');

        // 设置表头样式:居中对齐和加粗
        $headerStyle = [
            'font' => [
                'bold' => true,  // 加粗
                'size' => 12,    // 字体大小
            ],
            'alignment' => [
                'horizontal' => Alignment::HORIZONTAL_CENTER,  // 水平居中
                'vertical' => Alignment::VERTICAL_CENTER,      // 垂直居中
            ]
        ];

        // 应用样式到表头
        $sheet->getStyle('A1:D1')->applyFromArray($headerStyle);

        // 填充数据
        $rowNum = 2;  // 从第二行开始填充数据
        foreach ($employees as $employee) {
            $sheet->setCellValue('A' . $rowNum, $employee['emp_name']);
            $sheet->setCellValue('B' . $rowNum, $employee['emp_sex']);
            $sheet->setCellValue('C' . $rowNum, $employee['emp_phone']);
            $sheet->setCellValue('D' . $rowNum, $employee['create_time']);
            $rowNum++;
        }

        /*$writer = new Xlsx($spreadsheet);
        $writer->save('demo.xlsx');*/
        header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
        header('Content-Disposition: attachment;filename="myfile.xlsx"');
        header('Cache-Control: max-age=0');

        $writer = \PhpOffice\PhpSpreadsheet\IOFactory::createWriter($spreadsheet, 'Xlsx');
        $writer->save('php://output');
        return json(['code'=>200,'msg'=>'success']);
    }
}
bash 复制代码
composer require phpoffice/phpspreadsheet

根据phpspreadsheet官方文档,写了上述代码,如有不懂的地方,请查阅官方文档。

相关推荐
Android-Flutter2 分钟前
kotlin - 2个Fragment实现左右显示,左边列表,右边详情,平板横、竖屏切换
android·kotlin
charlie11451419111 分钟前
Android开发——初步了解AndroidManifest.xml
android·xml·开发语言·学习·安卓·安全架构
黎宇幻生15 分钟前
Java全栈学习笔记30
android·adb
一个尚在学习的计算机小白40 分钟前
spring
android·java·spring
时光少年1 小时前
Android 喷雾效果实现
android·前端
tangweiguo030519871 小时前
Android应用完全重启指南:从任务重置到进程重生
android
2501_916007471 小时前
uni-app iOS 文件调试常见问题与解决方案:结合 itools、克魔、iMazing 的实战经验
android·ios·小程序·https·uni-app·iphone·webview
Source.Liu2 小时前
【Python自动化】 21 Pandas Excel 操作完整指南
python·excel·pandas
ljt27249606612 小时前
Compose笔记(四十九)--SwipeToDismiss
android·笔记·android jetpack
fatiaozhang95272 小时前
山西移动九联UNT413HS-海思MV320-2+8G-原机全量备份包
android·电脑·电视盒子·刷机固件·机顶盒刷机