各类知识收集,PHP技术分享与解决方案各类知识收集,PHP技术分享与解决方案各类知识收集,PHP技术分享与解决方案

Str Tom,为分享PHP技术和解决方案,贡献一份自己的力量!
收藏本站(不迷路),每天更新好文章!
当前位置:首页 > CMS教程 > PHP

phpExcel将数据导出至Excel的详细方法介绍

管理员 2023-09-05
PHP
149

phpExcel将数据导出至Excel的详细方法介绍

内容导读

收集整理的这篇技术教程文章主要介绍了phpExcel将数据导出至Excel的详细方法介绍,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3224字,纯文字阅读大概需要5分钟

内容图文

本篇文章给大家带来的内容是关于phpExcel将数据导出至Excel的详细方法介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

安装类库

从GitHub上下载PHPExcel类库

地址:https://github.com/PHPOffice/PHPExcel

解压后将Classes文件夹移动到ThinkPHP的extend目录,并将其重命名为phpexcel

在项目中需要的地方添加引用

import('phpexcel.PHPExcel', EXTEND_PATH);

代码实现

<?phpnamespace appindexcontroller;use thinkController;class Excel extends Controller{    // 将数据导出至Excel    public function exportExcel()    {        // 引入类库        import('phpexcel.PHPExcel', EXTEND_PATH);        // 文件名和文件类型        $fileName = "student";        $fileType = "xlsx";        // 模拟获取数据        $data = self::getData();        $obj = new PHPExcel();        // 以下内容是excel文件的信息描述信息        $obj->getProperties()->setCreator(''); //设置创建者        $obj->getProperties()->setLastModifiedBy(''); //设置修改者        $obj->getProperties()->setTitle(''); //设置标题        $obj->getProperties()->setSubject(''); //设置主题        $obj->getProperties()->setDescription(''); //设置描述        $obj->getProperties()->setKeywords('');//设置关键词        $obj->getProperties()->setCategory('');//设置类型        // 设置当前sheet        $obj->setActiveSheetIndex(0);        // 设置当前sheet的名称        $obj->getActiveSheet()->setTitle('student');        // 列标        $list = ['A', 'B', 'C'];        // 填充第一行数据        $obj->getActiveSheet()            ->setCellValue($list[0] . '1', '学号')            ->setCellValue($list[1] . '1', '姓名')            ->setCellValue($list[2] . '1', '班级');        // 填充第n(n>=2, n∈N*)行数据        $length = count($data);        for ($i = 0; $i < $length; $i++) {            $obj->getActiveSheet()->setCellValue($list[0] . ($i + 2), '20190101', PHPExcel_Cell_DataType::TYPE_STRING);//将其设置为文本格式            $obj->getActiveSheet()->setCellValue($list[1] . ($i + 2), 'student01');            $obj->getActiveSheet()->setCellValue($list[2] . ($i + 2), '1班');        }        // 设置加粗和左对齐        foreach ($list as $col) {            // 设置第一行加粗            $obj->getActiveSheet()->getStyle($col . '1')->getFont()->setBold(true);            // 设置第1-n行,左对齐            for ($i = 1; $i <= $length + 1; $i++) {                $obj->getActiveSheet()->getStyle($col . $i)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_LEFT);            }        }        // 设置列宽        $obj->getActiveSheet()->getColumnDimension('A')->setWidth(20);        $obj->getActiveSheet()->getColumnDimension('B')->setWidth(20);        $obj->getActiveSheet()->getColumnDimension('C')->setWidth(15);        // 导出        ob_clean();        if ($fileType == 'xls') {            header('Content-Type: application/vnd.ms-excel');            header('Content-Disposition: attachment;filename="' . $fileName . '.xls');            header('Cache-Control: max-age=1');            $objWriter = new PHPExcel_Writer_Excel5($obj);            $objWriter->save('php://output');            exit;        } elseif ($fileType == 'xlsx') {            header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');            header('Content-Disposition: attachment;filename="' . $fileName . '.xlsx');            header('Cache-Control: max-age=1');            $objWriter = PHPExcel_IOFactory::createWriter($obj, 'Excel2007');            $objWriter->save('php://output');            exit;        }    }    // 准备数据    protected function getData()    {        $studentList = [            [                'stuNo' => '20190101',                'name' => 'student01',                'class' => '1班'            ], [                'stuNo' => '20190102',                'name' => 'student02',                'class' => '1班'            ], [                'stuNo' => '20190103',                'name' => 'student03',                'class' => '1班'            ]        ];        return $studentList;    }}

运行

浏览器访问http://127.0.0.1:8083/index/excel/exportExcel下载Excel文件

打开文件如下:

可以看到Excel中的数据和PHP数组中的数据是一致的!

以上就是phpExcel将数据导出至Excel的详细方法介绍的详细内容,更多请关注Gxl网其它相关文章!

内容总结

以上是为您收集整理的phpExcel将数据导出至Excel的详细方法介绍全部内容,希望文章能够帮你解决phpExcel将数据导出至Excel的详细方法介绍所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

扫码关注

qrcode

QQ交谈

回顶部