您好,欢迎访问一九零五行业门户网

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

本篇文章给大家带来的内容是关于phpexcel将数据导出至excel的详细方法介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
安装类库
从github上下载phpexcel类库
地址:https://github.com/phpoffice/phpexcel
解压后将classes文件夹移动到thinkphp的extend目录,并将其重命名为phpexcel
在项目中需要的地方添加引用
import('phpexcel.phpexcel', extend_path);
代码实现
<?phpnamespace app\index\controller;use think\controller;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的详细方法介绍的详细内容。
其它类似信息

推荐信息