ThinkPHP3.2 + PHPExcel 进行execl文件导出操作

2024-01-27 18:38

本文主要是介绍ThinkPHP3.2 + PHPExcel 进行execl文件导出操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本次是进行execl导出实例的讲解,

1、首先下载PHPExcel扩展类 (可以百度   没有的找我要157400661@qq.com)


2、在ThinkPHP引入PHPExcel  那么我是放到了Vendor中


3、然后就可以开心的去写控制器方法了

注意要这样写去引用哦 $excel = new \PHPExcel();

因为我是导出excel 先保存到服务器然后再将导出的文件和其他文件一起进行压缩后下载的(文件合并压缩后续我会再写文档介绍) 所以这段代码最后ajax返回的操作可以不用管

如果大家想直接导出后就下载  可以参考最后注释的几行

/*** 真正的导出* @param  array $complain_info 投诉信息结构体* $is_download_mv  是否下载视频* @return [type]                [description]*/public function export_complain($complain_info,$is_download_mv){Vendor('PHPExcel.PHPExcel','','.class.php');//创建对象$excel = new \PHPExcel();$excel->getActiveSheet()->setTitle('投诉列表');// 设置单元格高度// 所有单元格默认高度$excel->getActiveSheet()->getDefaultRowDimension()->setRowHeight(25);// 第一行的默认高度$excel->getActiveSheet()->getRowDimension('1')->setRowHeight(30);// 垂直居中$excel->getActiveSheet()->getDefaultStyle()->getAlignment()->setVertical(\PHPExcel_Style_Alignment::VERTICAL_CENTER);// 设置水平居中$excel->getActiveSheet()->getDefaultStyle()->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);//Excel表格式$letter = array('A','B','C','D','E','F','F','G','H','I','J','K','L');//表头数组$tableheader = array('序号','车牌号','车牌颜色','投诉说明','投诉地点','投诉人','投诉时间','投诉人手机号','投诉人微信号','微信昵称','状态','进展','奖励');$tablestyle = array(array('width'=>'5'),array('width'=>'15'),array('width'=>'10'),array('width'=>'40'),array('width'=>'30'),array('width'=>'10'),array('width'=>'15'),array('width'=>'15'),array('width'=>'15'),array('width'=>'15'),array('width'=>'10'),array('width'=>'10'),array('width'=>'10'),);// 如果选择视频下载if($is_download_mv){$letter[] = 'M';$tableheader[] = '视频地址(相对路径)';$tablestyle[] = array('width'=>'30');}// id , plate_num,color,msg,place,name,time,phone,weixin,wx_name,status,process//填充表头信息for($i = 0;$i < count($tableheader);$i++) {$excel->getActiveSheet()->setCellValue("$letter[$i]1","$tableheader[$i]");$excel->getActiveSheet()->getColumnDimension($letter[$i])->setWidth($tablestyle[$i]['width']);}//填充表格信息for ($i = 2;$i <= count($complain_info) + 1;$i++) {$data = $complain_info[$i - 2];if($is_download_mv){$this->mv_arr[] = $data['vedio'];$tmp = explode('/',$data['vedio']);$tmpurl = array_pop($tmp);$excel->getActiveSheet()->setCellValue("$letter[13]$i","{$tmpurl}");}$excel->getActiveSheet()->setCellValue("$letter[0]$i","{$data['id']}");$excel->getActiveSheet()->setCellValue("$letter[1]$i","{$data['plate_num']}");$excel->getActiveSheet()->setCellValue("$letter[2]$i","{$data['color_str']}");$excel->getActiveSheet()->setCellValue("$letter[3]$i","{$data['msg']}");$excel->getActiveSheet()->setCellValue("$letter[4]$i","{$data['place']}");$excel->getActiveSheet()->setCellValue("$letter[5]$i","{$data['name']}");$excel->getActiveSheet()->setCellValue("$letter[6]$i","{$data['time']}");$excel->getActiveSheet()->setCellValue("$letter[7]$i","{$data['phone']}");$excel->getActiveSheet()->setCellValue("$letter[8]$i","{$data['weixin']}");$excel->getActiveSheet()->setCellValue("$letter[9]$i","{$data['wx_name']}");$excel->getActiveSheet()->setCellValue("$letter[10]$i","{$data['status_str']}");$excel->getActiveSheet()->setCellValue("$letter[11]$i","{$data['process_str']}");$excel->getActiveSheet()->setCellValue("$letter[12]$i","{$data['gift_send_str']}");}//创建Excel输入对象$write = new \PHPExcel_Writer_Excel5($excel);$filename = $this->execl_url.'/report_list_'.date("Y-m-d-H.i.s").'.xls';$write->save($filename);// 进行下一步文件压缩if($is_download_mv){$this->mv_arr[] = $filename;$this->filezip();}else{$result['code'] =200;$result['filename'] =$filename;$this->ajaxReturn($result);return true;}echo 0;
//		直接下载的代码
//		header("Pragma: public");
//		header("Expires: 0");
//		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="客栈信息.xls"');
//		header("Content-Transfer-Encoding:binary");
//		$write->save('php://output');}

导出后直接下载代码

   //创建Excel输入对象$write = new \PHPExcel_Writer_Excel5($excel);$write->save($filename);//      直接下载的代码header("Pragma: public");header("Expires: 0");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="客栈信息.xls"');header("Content-Transfer-Encoding:binary");$write->save('php://output');


这篇关于ThinkPHP3.2 + PHPExcel 进行execl文件导出操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/651137

相关文章

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

遮罩,在指定元素上进行遮罩

废话不多说,直接上代码: ps:依赖 jquer.js 1.首先,定义一个 Overlay.js  代码如下: /*遮罩 Overlay js 对象*/function Overlay(options){//{targetId:'',viewHtml:'',viewWidth:'',viewHeight:''}try{this.state=false;//遮罩状态 true 激活,f

动手学深度学习【数据操作+数据预处理】

import osos.makedirs(os.path.join('.', 'data'), exist_ok=True)data_file = os.path.join('.', 'data', 'house_tiny.csv')with open(data_file, 'w') as f:f.write('NumRooms,Alley,Price\n') # 列名f.write('NA

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

线程的四种操作

所属专栏:Java学习        1. 线程的开启 start和run的区别: run:描述了线程要执行的任务,也可以称为线程的入口 start:调用系统函数,真正的在系统内核中创建线程(创建PCB,加入到链表中),此处的start会根据不同的系统,分别调用不同的api,创建好之后的线程,再单独去执行run(所以说,start的本质是调用系统api,系统的api

Java IO 操作——个人理解

之前一直Java的IO操作一知半解。今天看到一个便文章觉得很有道理( 原文章),记录一下。 首先,理解Java的IO操作到底操作的什么内容,过程又是怎么样子。          数据来源的操作: 来源有文件,网络数据。使用File类和Sockets等。这里操作的是数据本身,1,0结构。    File file = new File("path");   字

MySQL——表操作

目录 一、创建表 二、查看表 2.1 查看表中某成员的数据 2.2 查看整个表中的表成员 2.3 查看创建表时的句柄 三、修改表 alter 3.1 重命名 rename 3.2 新增一列 add 3.3 更改列属性 modify 3.4 更改列名称 change 3.5 删除某列 上一篇博客介绍了库的操作,接下来来看一下表的相关操作。 一、创建表 create

MySQL使用mysqldump导出数据

mysql mysqldump只导出表结构或只导出数据的实现方法 备份数据库: #mysqldump 数据库名 >数据库备份名 #mysqldump -A -u用户名 -p密码 数据库名>数据库备份名 #mysqldump -d -A --add-drop-table -uroot -p >xxx.sql 1.导出结构不导出数据 mysqldump --opt -d 数据库名 -u

Python脚本:对文件进行批量重命名

字符替换:批量对文件名中指定字符进行替换添加前缀:批量向原文件名添加前缀添加后缀:批量向原文件名添加后缀 import osdef Rename_CharReplace():#对文件名中某字符进行替换(已完结)re_dir = os.getcwd()re_list = os.listdir(re_dir)original_char = input('请输入你要替换的字符:')replace_ch