1,使用composer安装phpexcel包:

composer require phpoffice/phpexcel

2,在控制器中创建方法:

(1)使用PHPexcel扩展。代码如下

 /**
* 导出excel表格(默认格式)
*
* @param array $columName 第一行的列名称
* @param array $list 二维数组
* @param string $setTitle sheet名称
* @return
* @author Tggui <tggui@vip.qq.com>
*/
private function exportExcel1($columName, $list, $fileName='demo', $setTitle='Sheet1'){ vendor('phpoffice.phpexcel.Classes.PHPexcel');
vendor('phpoffice.phpexcel.Classes.PHPexcel.IOFactory'); if ( empty($columName) || empty($list) ) {
return '列名或者内容不能为空';
}
if ( count($list[0]) != count($columName) ) {
return '列名跟数据的列不一致';
}
$fileName = iconv("utf-8", "gb2312", $fileName);
//实例化PHPExcel类
$PHPExcel = new \PHPExcel();
//获得当前sheet对象
$PHPSheet = $PHPExcel -> getActiveSheet();
//定义sheet名称
$PHPSheet -> setTitle($setTitle); //excel的列 这么多够用了吧?不够自个加 AA AB AC ……
$letter = [
'A','B','C','D','E','F','G','H','I','J','K','L','M',
'N','O','P','Q','R','S','T','U','V','W','X','Y','Z'
];
//把列名写入第1行 A1 B1 C1 ...
for ($i=0; $i < count($list[0]); $i++) {
//$letter[$i]1 = A1 B1 C1 $letter[$i] = 列1 列2 列3
$PHPSheet->setCellValue("$letter[$i]1","$columName[$i]");
}
//内容第2行开始
foreach ($list as $key => $val) {
//array_values 把一维数组的键转为0 1 2 3 ..
foreach (array_values($val) as $key2 => $val2) {
//$letter[$key2].($key+2) = A2 B2 C2 ……
$PHPSheet->setCellValue($letter[$key2].($key+2),$val2);
}
}
//生成2007版本的xlsx
$PHPWriter = \PHPExcel_IOFactory::createWriter($PHPExcel,'Excel2007');
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Disposition: attachment;filename='.$fileName.'.xlsx');
header('Cache-Control: max-age=0');
$PHPWriter->save("php://output");
exit;
}

2),自定义函数,不使用PHPexcel扩展。代码如下:

/**
* 导出excel表格
*
* @param array $columName 第一行的列名称
* @param array $list 二维数组
* @param string $setTitle sheet名称
* @return
* @author Tggui <tggui@vip.qq.com>
*/
public function exportExcel($columName, $data, $fileName='demo', $setTitle='Sheet1'){
$table = '<table border=1>';
if(!empty($columName) && is_array($columName)){
$table .= "<thead><tr>";
foreach($columName as $key=>$value){
$table .= "<th style='background:#badffb'>{$value}</th>";
}
$table .= "</tr></thead>";
}
$table .= "<tbody>";
if(!empty($data) && is_array($columName)){
foreach($data as $k=>$v){
$table .= "<tr>";
foreach($v as $vk=>$vv){
$table .= "<td>{$vv}</td>";
} $table .= "</tr>";
}
}
$table .= "</tbody></table>"; //通过header头控制输出excel表格
header("Pragma: public");
header("Expires: 0");
header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
header("Content-Type:application/force-download");
header("Content-Type:application/vnd.ms-execl");
header("Content-Type:application/octet-stream");
header("Content-Type:application/download");
header('Content-Disposition:attachment;filename="'.$fileName.'.xls"');
header("Content-Transfer-Encoding:binary");
echo $table;
}
}

3,创建导出测试方法:

/**
* @method 导出测试方法
*/
public function connectOrder()
{
//连接数据库获取数据
$clt_db = Db::connect('clt_db');
$data = $clt_db->name('admin')
->field('username,extension,email,tel')
->select();
//第一行的列数据
$header = array('用户名', '工号', '邮箱', '电话号码'); //调用导出方法
self::exportExcel1($header, $data, date('Y-m-d'));
}

参考于:https://blog.csdn.net/dream__skyfly/article/details/85226194

tp5使用PHPexcel扩展导出excel表的更多相关文章

  1. tp5.0 composer下载phpexcel 实现导出excel 表格

    tp5.0 composer下载phpexcel 实现导出excel 表格 1.在下载好的tp5.0 框架里面使用 composer 下载phpexcel 的插件 composer require p ...

  2. thinkphp导入导出excel表单数据

    在PHP项目经常要导入导出Excel表单. 先去下载PHPExcel类库文件,放到相应位置. 我在thinkphp框架中的位置为ThinkPHP/Library/Org/Util/ 导入 在页面上传e ...

  3. 【ITOO 1】将List数据导出Excel表

    需求描述:在课表导入的时候,首先给用户提供模板(excel),然后将用户填写好的数据读取到list集合中.再进行判空处赋值处理,以及去重处理.这篇博客,主要介绍读取excel表和导出excel表的方法 ...

  4. ASP.NET导出excel表方法汇总

    asp.net里导出excel表方法汇总  1.由dataset生成 public void CreateExcel(DataSet ds,string typeid,string FileName) ...

  5. DateGridew导出Excel表+常见错误提示

    在敲机房收费系统的时候,显示数据的时候需要将DateGridew 中的数据导出进Excel表.DateGridew导出Excel表是比较常见的,当然导出Excel表有很多种方法,下面是个人认为比较容易 ...

  6. 使用PHPExcel导入导出excel格式文件

    使用PHPExcel导入导出excel格式文件  作者:zccst  因为导出使用较多,以下是导出实现过程.  第一步,将PHPExcel的源码拷贝到项目的lib下  文件包含:PHPExcel.ph ...

  7. 传参导出Excel表乱码问题解决方法

    业务场景 先描述一下业务场景,要实现的功能是通过搜索框填写参数,然后点击按钮搜索数据,将搜索框的查询参数获取,附加在链接后面,调导Excel表接口,然后实现导出Excel功能.其实做导Excel表功能 ...

  8. 前端导出excel表

    前端导出excel表 方式一: 前端js实现 : https://www.cnblogs.com/zhangym118/p/6235801.html 方式二: java后端实现: https://bl ...

  9. C# asp.net中导出Excel表时总出现"只能在执行 Render() 的过程中调用 RegisterForEventValidation

    C# asp.net中导出Excel表时总出现"只能在执行 Render() 的过程中调用 RegisterForEventValidation 后台添加以下方法:/// <summa ...

随机推荐

  1. 菜鸡发现腾讯视频bug

    腾讯视频bug 我看一个将夜,出现三生三世? 这是为啥? 发现bug,会得到奖励吗? 不会像dnf一样游戏自己的bug,然后出现伤害999,把我号封了. 我这样会被封号吗?我应该怎么做才不会被封?好慌 ...

  2. CNN中的feature map

    个人学习CNN的一些笔记,比较基础,整合了其他博客的内容 feature map的理解在cnn的每个卷积层,数据都是以三维形式存在的.你可以把它看成许多个二维图片叠在一起(像豆腐皮竖直的贴成豆腐块一样 ...

  3. IP unnumbered interface,某个接口不编号,某个接口不分配IP地址

    OSPFv2中,提到点到点链路可以是unnumbered,不编号,不分配IP地址 12.4.1.1.  Describing point-to-point interfaces             ...

  4. 杭电-------2052Picture(C语言)

    #include<stdio.h> int main() { int width, height; int i, j; while (~scanf("%d %d", & ...

  5. Day17-18前端学习之路——Javascript事件

    用户在某个元素上点击鼠标或悬停光标. 用户在键盘中按下某个按键. 用户调整浏览器的大小或者关闭浏览器窗口. 一个网页停止加载. 提交表单. 播放.暂停.关闭视频. 发生错误. 更多事件:https:/ ...

  6. 小白学 Python 数据分析(9):Pandas (八)数据预处理(2)

    人生苦短,我用 Python 前文传送门: 小白学 Python 数据分析(1):数据分析基础 小白学 Python 数据分析(2):Pandas (一)概述 小白学 Python 数据分析(3):P ...

  7. js函数与作用域,了解函数基本概念

    通过js基础语法了解到js的值包含数字,字符串和布尔值;js运算符分为算数,赋值,比较和逻辑运算符;js的流程控制包含条件判断if,switch选择;循环for while:下面js的函数及作用域,学 ...

  8. 【算法】蓝桥杯 试题 基础练习 Huffuman树

    资源限制 时间限制:1.0s   内存限制:512.0MB 问题描述 Huffman树在编码中有着广泛的应用.在这里,我们只关心Huffman树的构造过程. 给出一列数{pi}={p0, p1, …, ...

  9. #《Essential C++》读书笔记# 第三章 泛型编程风格

    基础知识 array与vector是连续存储空间,可以用指针的算术运算实现对容器的访问.list也是一个容器,不同的是,list的元素以一组指针相互链接(linked):前向(forward)指针指向 ...

  10. P1843 奶牛晒衣服

    链接:Miku -------------------------------- 这是一道二分答案的题,我们要二分时间. 对于每件衣服,我们自然是能让它自己蒸发就自己蒸发,这样才是最优的. 那么我闷可 ...