tp5使用PHPexcel扩展导出excel表
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表的更多相关文章
- tp5.0 composer下载phpexcel 实现导出excel 表格
tp5.0 composer下载phpexcel 实现导出excel 表格 1.在下载好的tp5.0 框架里面使用 composer 下载phpexcel 的插件 composer require p ...
- thinkphp导入导出excel表单数据
在PHP项目经常要导入导出Excel表单. 先去下载PHPExcel类库文件,放到相应位置. 我在thinkphp框架中的位置为ThinkPHP/Library/Org/Util/ 导入 在页面上传e ...
- 【ITOO 1】将List数据导出Excel表
需求描述:在课表导入的时候,首先给用户提供模板(excel),然后将用户填写好的数据读取到list集合中.再进行判空处赋值处理,以及去重处理.这篇博客,主要介绍读取excel表和导出excel表的方法 ...
- ASP.NET导出excel表方法汇总
asp.net里导出excel表方法汇总 1.由dataset生成 public void CreateExcel(DataSet ds,string typeid,string FileName) ...
- DateGridew导出Excel表+常见错误提示
在敲机房收费系统的时候,显示数据的时候需要将DateGridew 中的数据导出进Excel表.DateGridew导出Excel表是比较常见的,当然导出Excel表有很多种方法,下面是个人认为比较容易 ...
- 使用PHPExcel导入导出excel格式文件
使用PHPExcel导入导出excel格式文件 作者:zccst 因为导出使用较多,以下是导出实现过程. 第一步,将PHPExcel的源码拷贝到项目的lib下 文件包含:PHPExcel.ph ...
- 传参导出Excel表乱码问题解决方法
业务场景 先描述一下业务场景,要实现的功能是通过搜索框填写参数,然后点击按钮搜索数据,将搜索框的查询参数获取,附加在链接后面,调导Excel表接口,然后实现导出Excel功能.其实做导Excel表功能 ...
- 前端导出excel表
前端导出excel表 方式一: 前端js实现 : https://www.cnblogs.com/zhangym118/p/6235801.html 方式二: java后端实现: https://bl ...
- C# asp.net中导出Excel表时总出现"只能在执行 Render() 的过程中调用 RegisterForEventValidation
C# asp.net中导出Excel表时总出现"只能在执行 Render() 的过程中调用 RegisterForEventValidation 后台添加以下方法:/// <summa ...
随机推荐
- 版本控制工具-svn
两个疑问: 1.什么是版本控制? 2.为什么要用版本控制工具? 银联卡的特征: 1.受保护的 2.受约束的 如何与银联卡对应? 1.个人的代码--口袋里的钱 2.版本控制工具中的代码--银联卡里的钱 ...
- Linux 内存分析工具——free命令
在Linux系统经常被用作服务器系统.当服务器内存吃紧的时候,free命令是我们最常使用的内存分析工具. free使用介绍 free命令可以显示Linux系统中空闲的.已用的物理内存及swap内存,及 ...
- jQuery 基础 (笔记源于runoob)
您需要具备的基础知识 在您开始学习 jQuery 之前,您应该对以下知识有基本的了解: HTML CSS JavaScript jQuery ? jQuery是一个JavaScript函数库. jQu ...
- postman之下载文件
前言 小伙伴们在实际的测试工作中是否遇到过下载的接口呢,例如网盘的项目就涉及到上传和下载的接口了,那么我们如何利用postman对下载接口进行测试呢?下面我们一起来学习吧! 练习案例:下载接口:htt ...
- NR / 5G - MAC Scheduler
- Vue项目使用vant框架
近期在开发h5端项目,用到vant框架,vant是一款基于Vue的移动UI组件,看了vant的官方文档(https://youzan.github.io/vant/#/zh-CN/)感觉不错,功能比较 ...
- STM32F4相关
常用术语 AHB与APB的地位相当于PC中的南北桥,是两道独立的片内总线.AHB:advanced high-performance bus:APB: advanced peripherals bus
- hive使用beeline无法登录时的解决办法
如果参考官方文档执行下列命令,报错: $ $HIVE_HOME/bin/hiveserver2 $ $HIVE_HOME/bin/beeline -u jdbc:hive2://$HS2_HOST:$ ...
- android手机遍历安装应用
/** * 遍历程序列表,判断是否安装安全支付服务 * * @return */ public boolean isMobile_spExist() { PackageManager manager ...
- Python学习小记(5)---Magic Method
具体见The Python Language Reference 与Attribute相关的有 __get__ __set__ __getattribute__ __getattr__ __setat ...