thinkphp5中使用PHPExcel(转载)
thinkphp5中可以使用composer来获取第三方类库,使用起来特别方便,例如:可是使用composer下载PHPMailer,think-captcha(验证码)等等……
接下来说一下怎么使用PHPExcel,这是一个很好用的第三方类库。
1.使用composer下载PHPExcel,首先安装过composer之后,用dos命令行,引入到项目所在目录下,然后输入composer require phpexcel/phpexcel ,然后点回车键
2.在thinkphp中使用,大概分为四个步骤。
最简单的生成Excel文件
- $objPHPExcel = new \PHPExcel();
这里可能会遇到一个问题,报这样的错误。
- $objSheet = $objPHPExcel->getActiveSheet();
- $objSheet ->setTitle("demo");//可以给sheet设置名称为"demo"
(3)<1>然后就是在表格中写入数据
- $objSheet->setCellValue("A1","姓名")->setCellValue("B1","分数");
- $objSheet->setCellValue("A2","张三")->setCellValue("B2","100");
- $array = array(
- array(),
- array('姓名','分数'),
- array('张三','60'),
- array('李四','61'),
- array('王五','62'),
- );
- $objSheet -> fromArray($array);//数据较大时,不建议使用此方法,建议使用setCellValue()
(4)最后就是保存写好的数据
- $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');//生成一个Excel2007文件
- $objWriter->save('E:/test.xlsx');//保存文件
从数据库中到导出文件
- $path = 'E:/';
- $name = 'think_admin';
- $objPHPExcel = new \PHPExcel();
- for ($i=1; $i < 3; $i++) {
- if ($i>1) {
- $objPHPExcel->createSheet();
- }
- $objPHPExcel->setActiveSheetIndex($i-1);//把当前创建的sheet设置为活动sheet
- $objSheet = $objPHPExcel->getActiveSheet();//获得当前活动Sheet
- $objSheet->setTitle("user".$i);
- if($i==1){
- $db_admin = db('admin')->where('sex','男')->select();
- }else{
- $db_admin = db('admin')->where('sex','女')->select();
- }
- $objSheet->setCellValue('A1','id')->setCellValue('B1','user')->setCellValue('C1','name')->setCellValue('D1','password')
- ->setCellValue('E1','imgpath')->setCellValue('F1','tel')->setCellValue('G1','sex')->setCellValue('H1','age');
- $j = 2;
- foreach ($db_admin as $key => $value) {
- $objSheet->setCellValue('A'.$j,$value['id'])->setCellValue('B'.$j,$value['user'])->setCellValue('C'.$j,$value['name'])
- ->setCellValue('D'.$j,$value['password'])
- ->setCellValue('E'.$j,$value['imgpath'])->setCellValue('F'.$j,$value['tel'])->setCellValue('G'.$j,$value['sex'])
- ->setCellValue('H'.$j,$value['age']);
- $j++;
- }
- }
- $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
- $objWriter->save($path.$name.'.xlsx');
在浏览器上输出Excel文件(下载)
- $filename = 'think_admin.xls';
- $objPHPExcel = new \PHPExcel();
- for ($i=1; $i < 3; $i++) {
- if ($i>1) {
- $objPHPExcel->createSheet();
- }
- $objPHPExcel->setActiveSheetIndex($i-1);//把当前创建的sheet设置为活动sheet
- $objSheet = $objPHPExcel->getActiveSheet();//获得当前活动Sheet
- $objSheet->setTitle("user".$i);
- if($i==1){
- $db_admin = db('admin')->where('sex','男')->select();
- }else{
- $db_admin = db('admin')->where('sex','女')->select();
- }
- $objSheet->setCellValue('A1','id')->setCellValue('B1','user')->setCellValue('C1','name')->setCellValue('D1','password')
- ->setCellValue('E1','imgpath')->setCellValue('F1','tel')->setCellValue('G1','sex')->setCellValue('H1','age');
- $j = 2;
- foreach ($db_admin as $key => $value) {
- $objSheet->setCellValue('A'.$j,$value['id'])->setCellValue('B'.$j,$value['user'])->setCellValue('C'.$j,$value['name'])->setCellValue('D'.$j,$value['password'])
- ->setCellValue('E'.$j,$value['imgpath'])->setCellValue('F'.$j,$value['tel'])->setCellValue('G'.$j,$value['sex'])->setCellValue('H'.$j,$value['age']);
- $j++;
- }
- }
- $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
- header('Content-Type: application/vnd.ms-excel');//告诉浏览器将要输出excel03文件
- header('Content-Disposition: attachment;filename="'.$filename.'"');//告诉浏览器将输出文件的名称(文件下载)
- header('Cache-Control: max-age=0');//禁止缓存
- $objWriter->save("php://output");
转载地址:http://blog.csdn.net/Iloveyougirls/article/details/53212402
thinkphp5中使用PHPExcel(转载)的更多相关文章
- thinkphp5中使用phpmailer实现发送邮件功能(转载)
一.开启SMTP服务(使用php发送邮件需要用到SMTP服务,这里以163邮箱的SMTP服务为例). 1.登录163邮箱,在首页上找到“设置”. 2.选择开启的服务,一般都全选,POP3/SMTP/I ...
- php中使用PHPExcel操作excel(xls)文件
读取中文的xls.csv文件会有问题,网上找了下资料,发现PHPExcel类库好用,官网地址:http://phpexcel.codeplex.com/ 1.读取xls文件内容 代码如下 复制代码 ...
- tp5.0中使用PHPexcel,以及Loader的一些问题
在5.0中使用PHPexcel遇到一些问题,记录一下方便以后查看. 非使用PHPexcel的方法: 参考:http://blog.csdn.net/sinat_35861727/article/det ...
- thinkphp5中如何使用 usort
thinkphp5中如何使用 usort 一.总结 一句话总结:其实比较函数加上命名空间就好啦,不然找不到 比较函数加命名空间 数组做usort的第二个参数 usort($question_list, ...
- git在eclipse中的配置 转载
git在eclipse中的配置 转载 一_安装EGIT插件 http://download.eclipse.org/egit/updates/ 或者使用Eclipse Marketplace,搜索EG ...
- thinkphp5中的配置如何使用
thinkphp5中的配置如何使用 一.总结 一句话总结:先加载配置,然后读取配置即可 加载配置 读取配置 Config::load(APP_PATH.'fry_config.php');\\加载配置 ...
- thinkphp5中的一些关于命名空间的tisp
1.thinkphp5中公共函数文件common中,不需要use,也可以直接使用vendor中的类文件. 2.在类前面的反斜杠作用是,直接使用最外层的命名空间,有时不想use某个X类,却想使用X类时, ...
- C#高级编程六十九天----DLR简介 .在.NET中使用DLR(转载) 我也来说说Dynamic
DLR 一.近年来,在TIOBE公司每个月发布的编程语言排行榜中,C#总是能挤进前十名,而在最近十年来,C#总体上呈现上升的趋势.C#能取得这样的成绩,有很多因素,其中它在语言特性上的锐意进取让人印象 ...
- C# json反序列化 对象中嵌套数组 (转载) 可能会导致循环或多重级联路径。请指定 ON DELETE NO ACTION 或 ON UPDATE NO ACTION,或修改其他 FOREIGN KEY 约束。
C# json反序列化 对象中嵌套数组 (转载) 看图: 这里可以看到是二层嵌套!!使用C#如何实现?? 思路:使用list集合实现 → 建立类 → list集合 → 微软的 Newtonso ...
随机推荐
- 咏南新CS三层开发框架
咏南新CS三层开发框架 咏南WEB桌面框架演示:47.106.93.126:9999 咏南WEB手机框架本地:47.106.93.126:8077 咏南CS框架下载:https://pan.baidu ...
- CoordinatorLayout使用详解: 打造折叠悬浮效果
1.简介 CoordinatorLayout遵循Material 风格,包含在 support Library中,结合AppbarLayout, CollapsingToolbarLayout等 可 ...
- ssh-keygen 基本用法
ssh-keygen命令用于为"ssh"生成.管理和转换认证密钥,它支持RSA和DSA两种认证密钥. ssh-keygen(选项) -b:指定密钥长度: -e:读取openssh的 ...
- 让Linux系统开机速度更快的方法
进行 Linux 内核与固件开发的时候,往往需要多次的重启,会浪费大把的时间. 在所有我拥有或使用过的电脑中,启动最快的那台是 20 世纪 80 年代的电脑.在你把手从电源键移到键盘上的时候,BASI ...
- 解决TextView drawableRight左侧图片大小不可控的问题
通过代码来修改图片的大小: Drawable rightDrawable= context.getResources().getDrawable(R.drawable.more); rightDraw ...
- Nload(CentOS网速的实时监控)
Nload(CentOS网速的实时监控)的安装和安装过程中的问题 I. 安装 Download the latest rpmforge-release rpm from wget ftp://ftp. ...
- 分析轮子(八)- List.java 各种遍历方式及遍历时移除元素的方法
注:玩的是JDK1.7版本 1:先尝栗子,再分析,代码简单,注释清晰,可自玩一下 /** * @description:测试集合遍历和移除元素的方式 * @author:godtrue * @crea ...
- koa中间件机制详解
转自:https://cnodejs.org/topic/58fd8ec7523b9d0956dad945 koa是由express原班人马打造的一个更小.更富有表现力.更健壮的web框架. 在我眼中 ...
- Docker使用exec进入正在运行中的容器
docker在1.3.X版本之后提供了一个新的命令exec用于进入容器,这种方式相对简单一些,下面我们来看一下该命令的使用: docker exec --help 接下来我们使用该命令进入一个已经在运 ...
- Android中的指纹识别
转载请注明出处:http://blog.csdn.net/wl9739/article/details/52444671 评论中非常多朋友反映,依据我给出的方案,拿不到指纹信息这个问题,在这里统一说明 ...