Yii框架中导出excel文件

 1 <?php
 2
 3 namespace frontend\models;
 4 //include $_SERVER[‘DOCUMENT_ROOT‘].‘/PHPExcel/EXCEL/PHPExcel.php‘;
 5 // include ‘E:\www\WWW\advanced\common\widgets\PHPExcel\EXCEL\PHPExcel\Writer\Excel2007.php‘;
 6 use yii\base\Model;
 7
 8 /**
 9  * This is the model class for table "country".
10  *
11  * @property string $code
12  * @property string $name
13  * @property integer $population
14  */
15 class PHPExcel extends Model
16 {
17
18     //文件名
19     private $fileName = ‘user‘;
20
21     //构造函数
22     public function __construct($fileName = ‘‘)
23     {
24         $this->setFileName($fileName);
25     }
26
27     //设置要导出的文件名
28     public function setFileName($fileName)
29     {
30         $this->fileName = $fileName;
31     }
32
33     //开始下载
34     public function toDownload($strTable)
35     {
36         header("Content-type: application/vnd.ms-excel");
37         header("Content-Type: application/force-download");
38         header("Content-Disposition: attachment; filename=".$this->fileName."_".date(‘Y-m-d‘).".xls");
39         header(‘Expires:0‘);
40         header(‘Pragma:public‘);
41         echo ‘<html><meta http-equiv="Content-Type" content="text/html; charset=utf-8" />‘.$strTable.‘</html>‘;
42     }
43
44 }
 1 //点击生成单页数据的excel表格
 2     public function actionExcel()
 3     {
 4         $id = Yii::$app -> request ->get(‘id‘);
 5         $sql="select * from order_ticket where id IN ($id)";
 6         $result = \yii::$app->db->createCommand($sql)->queryAll();
 7         $strTable =‘<table width="500" border="1">‘;
 8         $strTable .= ‘<tr>‘;
 9         $strTable .= ‘<td style="text-align:center;font-size:12px;" width="150px">姓名</td>‘;
10         $strTable .= ‘<td style="text-align:center;font-size:12px;" width="*">手机</td>‘;
11         $strTable .= ‘<td style="text-align:center;font-size:12px;" width="*">开始时间</td>‘;
12         $strTable .= ‘<td style="text-align:center;font-size:12px;" width="*">结束时间</td>‘;
13         $strTable .= ‘<td style="text-align:center;font-size:12px;" width="*">电影名称</td>‘;
14         $strTable .= ‘<td style="text-align:center;font-size:12px;" width="*">座位</td>‘;
15         $strTable .= ‘</tr>‘;
16
17         foreach($result as $key=>$val)
18         {
19             $strTable .= ‘<tr>‘;
20             $strTable .= ‘<td style="text-align:center;font-size:12px;">‘.$val[‘reserve_name‘].‘ </td>‘;
21             $strTable .= ‘<td style="text-align:center;font-size:12px;">‘.$val[‘tel‘].‘ </td>‘;
22             $strTable .= ‘<td style="text-align:center;font-size:12px;">‘.$val[‘begin_time‘].‘</td>‘;
23             $strTable .= ‘<td style="text-align:center;font-size:12px;">‘.$val[‘end_time‘].‘ </td>‘;
24             $strTable .= ‘<td style="text-align:center;font-size:12px;">‘.$val[‘reserve_movie‘].‘ </td>‘;
25             $strTable .= ‘<td style="text-align:center;font-size:12px;">‘.$val[‘nameStr‘].‘ </td>‘;
26             $strTable .= ‘</tr>‘;
27         }
28         $strTable .=‘</table>‘;
29         $reportObj = new PHPExcel();
30         $reportObj->setFileName(‘demo‘);
31         $reportObj->toDownload($strTable);
32     }
时间: 2024-10-08 22:38:37

Yii框架中导出excel文件的相关文章

SpringMVC中导出Excel文件,关于弹出一个选择框,选择导出Excel文件的路径项目细节

最近项目上需要写一个导出excel功能,在开始的时候用ajax发送请求,不弹出导出路径选择框,后来在网上搜了一些资料,找到了问题所在,做一下总结: 前端页面:thymeleaf 后端语言:java 导出Excel:POI模式 1.ajax请求只是个“字符型”的请求,即请求的内容是以文本类型存放的.文件的下载是以二进制形式进行的,ajax没法解析后台返回的文件流,所以无法处理二进制流response输出来下载文件.将ajax请求改为loaction.href的形式发送请求,浏览器是可以识别二进制的

tp框架中导出csv文件excel能打开

控制器代码! public function dc(){ if($lx = I('get.lx'))        {            $where['zhonglei'] = array('eq',$lx);        }        if($qsrq = strtotime(I('get.qsrq')))        {            $where['time'] = array('gt',$qsrq);        }        if($jsrq = strto

Java web中不同浏览器间导出Excel文件名称乱码问题解决方案

问题描述: 对于不同浏览器存在对中文编码格式问题,从而在导出Excel文件时,中文文件名出现乱码的情况,即在程序中给要导出的文件指定一个中文名字时,在浏览器上出现的下载框中的文件名出现了乱码,解决如下: 解决方案: [java] view plain copy Date dt=new Date();//如果不需要格式,可直接用dt,dt就是当前系统时间 DateFormat df = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");//设置显示格

Springboot使用POI实现导出Excel文件示例

Springboot使用POI实现导出Excel文件示例 前面讲述了使用POI导出Word文件和读取Excel文件,这两个例子都相对简单,接下来要讲述的使用POI导出Excel文件要复杂得多,内容也会比较长.创建表头信息表头信息用于自动生成表头结构及排序public class ExcelHeader implements Comparable<ExcelHeader>{/**  * excel的标题名称  */private String title;/**  * 每一个标题的顺序  */p

基于Vue + axios + WebApi + NPOI导出Excel文件

一.前言 项目中前端采用的Element UI 框架, 远程数据请求,使用的是axios,后端接口框架采用的asp.net webapi,数据导出成Excel采用NPOI组件.其业务场景,主要是列表页(如会员信息,订单信息等)表格数据导出,如表格数据进行了条件筛选,则需要将条件传至后端api,筛选数据后,导出成Excel. 思考过前端导出的3种方案: 1.使用location.href 打开接口地址.缺点: 不能传token至后端api, 无法保证接口的安全性校验,并且接口只能是get方式请求.

使用Yii框架中遇到的三个问题

以下由我们在信易网络公司开发项目的时候终结出的一些经验 1.main.php文件中欲引入全局变量的问题 还原一下此问题:在Yii框架中,main.php一般会作为整个应用的配置文件,保存Application的各种参数,直接return数组.在使用的过程中,因为main.php文件一定会被Yii提前加载,所以将一些全局性的操作也放在了此文件,加载一些类操作啥的没有什么问题,当有一次加了一个全局变量,并且在其它地方使用global获取全局变量时,发现无论我如何努力都得到的是NULL.各种尝试后,终

PHP从数据库导出EXCEL文件

参考博客链接:http://www.cnblogs.com/huangcong/p/3687665.html 我的程序代码 原生导出Excel文件 <?phpheader('Content-type: text/html; charset=utf-8');header("Content-type:application/vnd.ms-excel");header("Content-Disposition:filename=test.xls"); $conn =

使用Open Xml按模版导出Excel文件(下)

(3)将数据写入Excel 把数据写入到Excel文件是本文的关键技术.这里需要用到OpenXml.在Sdk里已经提供了足够的文件操作方法,我们就调用这些方法,将数据源的数据写到文件中. 首先我们定义了一些工具类,用于读取单元格的行列值. 在Excel中,每个单元格都有一个地址:如B3表示第二行第三列的格子,在Utility中的GetRowIndex和GetColumnIndex就是输入字符串”B3”,返回Int类型的索引2 和3.还有输入“B3”,返回列的字母“B”等等. 在WorkSheet

PHP导出excel文件,第一步先实现PHP模板导出不带数据

今天继续研究PHP导出excel文件,把复杂的事情简单化,一步步实现功能,首先实现模板文件的导出,随后再实现写入数据后导出,最终实现功能,这是基本思路.中间可以加一步,先自己写入数据导出试试,随后再数据库导入.我首先把程序提交到自建的eubexcel.php文件,选用post提交,导出excel文件的程序在这个页面里书写,参考昨天下载的PHPExcel-1.8组件里的参考文档,先部署导出excel,具体代码如下 <?php error_reporting(E_ALL);ini_set('disp