thinkphp5中可以使用composer来获取第三方类库,使用起来特别方便,例如:可是使用composer下载PHPMailer,think-captcha(验证码)等等……

接下来说一下怎么使用PHPExcel,这是一个很好用的第三方类库。

1.使用composer下载PHPExcel,首先安装过composer之后,用dos命令行,引入到项目所在目录下,然后输入composer require phpexcel/phpexcel ,然后点回车键

你会发现项目的目录中在vendor的目录下多了一个文件夹(phpexcel),这个文件夹中的东西就是要使用的php中的Excel表格操作

2.在thinkphp中使用,大概分为四个步骤。

 

最简单的生成Excel文件

(1)首先第一步是:实例化phpexcel
  1. $objPHPExcel = new \PHPExcel();

这里可能会遇到一个问题,报这样的错误。

 
然后,搜索到这个文件把这一行去掉就ok。
(2)获得当前活动sheet,因为Excel有一个默认的sheet。
  1. $objSheet = $objPHPExcel->getActiveSheet();
  1. $objSheet ->setTitle("demo");//可以给sheet设置名称为"demo"

(3)<1>然后就是在表格中写入数据

  1. $objSheet->setCellValue("A1","姓名")->setCellValue("B1","分数");
  2. $objSheet->setCellValue("A2","张三")->setCellValue("B2","100");
<2>还有一个方法是用数组
  1. $array = array(
  2. array(),
  3. array('姓名','分数'),
  4. array('张三','60'),
  5. array('李四','61'),
  6. array('王五','62'),
  7. );
  8. $objSheet -> fromArray($array);//数据较大时,不建议使用此方法,建议使用setCellValue()

(4)最后就是保存写好的数据

  1. $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');//生成一个Excel2007文件
  2. $objWriter->save('E:/test.xlsx');//保存文件

从数据库中到导出文件

  1. $path = 'E:/';
  2. $name = 'think_admin';
  3. $objPHPExcel = new \PHPExcel();
  4. for ($i=1; $i < 3; $i++) {
  5. if ($i>1) {
  6. $objPHPExcel->createSheet();
  7. }
  8. $objPHPExcel->setActiveSheetIndex($i-1);//把当前创建的sheet设置为活动sheet
  9. $objSheet = $objPHPExcel->getActiveSheet();//获得当前活动Sheet
  10. $objSheet->setTitle("user".$i);
  11. if($i==1){
  12. $db_admin = db('admin')->where('sex','男')->select();
  13. }else{
  14. $db_admin = db('admin')->where('sex','女')->select();
  15. }
  16. $objSheet->setCellValue('A1','id')->setCellValue('B1','user')->setCellValue('C1','name')->setCellValue('D1','password')
  17. ->setCellValue('E1','imgpath')->setCellValue('F1','tel')->setCellValue('G1','sex')->setCellValue('H1','age');
  18. $j = 2;
  19. foreach ($db_admin as $key => $value) {
  20. $objSheet->setCellValue('A'.$j,$value['id'])->setCellValue('B'.$j,$value['user'])->setCellValue('C'.$j,$value['name'])
  21. ->setCellValue('D'.$j,$value['password'])
  22. ->setCellValue('E'.$j,$value['imgpath'])->setCellValue('F'.$j,$value['tel'])->setCellValue('G'.$j,$value['sex'])
  23. ->setCellValue('H'.$j,$value['age']);
  24. $j++;
  25. }
  26. }
  27. $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
  28. $objWriter->save($path.$name.'.xlsx');

在浏览器上输出Excel文件(下载)

  1. $filename = 'think_admin.xls';
  2. $objPHPExcel = new \PHPExcel();
  3. for ($i=1; $i < 3; $i++) {
  4. if ($i>1) {
  5. $objPHPExcel->createSheet();
  6. }
  7. $objPHPExcel->setActiveSheetIndex($i-1);//把当前创建的sheet设置为活动sheet
  8. $objSheet = $objPHPExcel->getActiveSheet();//获得当前活动Sheet
  9. $objSheet->setTitle("user".$i);
  10. if($i==1){
  11. $db_admin = db('admin')->where('sex','男')->select();
  12. }else{
  13. $db_admin = db('admin')->where('sex','女')->select();
  14. }
  15. $objSheet->setCellValue('A1','id')->setCellValue('B1','user')->setCellValue('C1','name')->setCellValue('D1','password')
  16. ->setCellValue('E1','imgpath')->setCellValue('F1','tel')->setCellValue('G1','sex')->setCellValue('H1','age');
  17. $j = 2;
  18. foreach ($db_admin as $key => $value) {
  19. $objSheet->setCellValue('A'.$j,$value['id'])->setCellValue('B'.$j,$value['user'])->setCellValue('C'.$j,$value['name'])->setCellValue('D'.$j,$value['password'])
  20. ->setCellValue('E'.$j,$value['imgpath'])->setCellValue('F'.$j,$value['tel'])->setCellValue('G'.$j,$value['sex'])->setCellValue('H'.$j,$value['age']);
  21. $j++;
  22. }
  23. }
  24. $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
  25. header('Content-Type: application/vnd.ms-excel');//告诉浏览器将要输出excel03文件
  26. header('Content-Disposition: attachment;filename="'.$filename.'"');//告诉浏览器将输出文件的名称(文件下载)
  27. header('Cache-Control: max-age=0');//禁止缓存
  28. $objWriter->save("php://output");

转载地址:http://blog.csdn.net/Iloveyougirls/article/details/53212402

thinkphp5中使用PHPExcel(转载)的更多相关文章

  1. thinkphp5中使用phpmailer实现发送邮件功能(转载)

    一.开启SMTP服务(使用php发送邮件需要用到SMTP服务,这里以163邮箱的SMTP服务为例). 1.登录163邮箱,在首页上找到“设置”. 2.选择开启的服务,一般都全选,POP3/SMTP/I ...

  2. php中使用PHPExcel操作excel(xls)文件

    读取中文的xls.csv文件会有问题,网上找了下资料,发现PHPExcel类库好用,官网地址:http://phpexcel.codeplex.com/ 1.读取xls文件内容  代码如下 复制代码 ...

  3. tp5.0中使用PHPexcel,以及Loader的一些问题

    在5.0中使用PHPexcel遇到一些问题,记录一下方便以后查看. 非使用PHPexcel的方法: 参考:http://blog.csdn.net/sinat_35861727/article/det ...

  4. thinkphp5中如何使用 usort

    thinkphp5中如何使用 usort 一.总结 一句话总结:其实比较函数加上命名空间就好啦,不然找不到 比较函数加命名空间 数组做usort的第二个参数 usort($question_list, ...

  5. git在eclipse中的配置 转载

    git在eclipse中的配置 转载 一_安装EGIT插件 http://download.eclipse.org/egit/updates/ 或者使用Eclipse Marketplace,搜索EG ...

  6. thinkphp5中的配置如何使用

    thinkphp5中的配置如何使用 一.总结 一句话总结:先加载配置,然后读取配置即可 加载配置 读取配置 Config::load(APP_PATH.'fry_config.php');\\加载配置 ...

  7. thinkphp5中的一些关于命名空间的tisp

    1.thinkphp5中公共函数文件common中,不需要use,也可以直接使用vendor中的类文件. 2.在类前面的反斜杠作用是,直接使用最外层的命名空间,有时不想use某个X类,却想使用X类时, ...

  8. C#高级编程六十九天----DLR简介 .在.NET中使用DLR(转载) 我也来说说Dynamic

    DLR 一.近年来,在TIOBE公司每个月发布的编程语言排行榜中,C#总是能挤进前十名,而在最近十年来,C#总体上呈现上升的趋势.C#能取得这样的成绩,有很多因素,其中它在语言特性上的锐意进取让人印象 ...

  9. C# json反序列化 对象中嵌套数组 (转载) 可能会导致循环或多重级联路径。请指定 ON DELETE NO ACTION 或 ON UPDATE NO ACTION,或修改其他 FOREIGN KEY 约束。

    C# json反序列化 对象中嵌套数组 (转载)   看图: 这里可以看到是二层嵌套!!使用C#如何实现?? 思路:使用list集合实现 → 建立类 → list集合 → 微软的   Newtonso ...

随机推荐

  1. Mac上搭建ELK

    转载自我的个人博客:http://blog.ywheel.cn/post/2017/03/04/setup_elk_on_mac/ 最近的项目需要对文本数据各字段进行快速检索.组合查询.模糊查询,在架 ...

  2. MySQL DBA工作角色和职责介绍

    MySQL DBA分架构DBA,运维DBA和开发DBA三种角色,职责介绍如下:

  3. MyBatis(五):mybatis关联映射

    Mybatis中表与表之间的关系分为一下4类: 1)一对一 2)一对多 3)多对一 4)多对多 创建数据Demo表 数据库表: 用户表user:记录了购买商品的用户信息. 订单表orders:记录了用 ...

  4. Win10系统的SurfacePro4的触摸笔如何使用

    初次使用需要配对,微软的触摸笔是蓝牙配对的,打开平板的蓝牙,长按触摸笔后面的按钮,触摸笔会闪烁小灯,平板会提示配对准备已就绪   点击配对之后,提示已连接   可以按下触摸笔后面的按钮,一键打开One ...

  5. Windows 7安装Tensorflow

    以前是在Cent OS中运行Tensorflow,,经常需要切换操作系统,很不方便,于是决定在Windows 7下安装Tensorflow. 过程还是挺复杂的,需要安装的包括:Visual Studi ...

  6. 通过Comparable来实现对自身的比较

    import org.apache.commons.lang.builder.CompareToBuilder; import org.apache.commons.lang.builder.Equa ...

  7. 【20180111】【物流FM专访】贝业新兄弟李济宏:我们是如何做到大件家居B2C物流第一的?

    在2017年的双11中,贝业新兄弟承接了日日顺家装和卫浴行业的仓储和配送,上海仓和武汉仓双十一期间及时出库率为100%,KPI位列第一:此外,贝业新兄弟还是科勒18年以来中国区唯一的物流服务商以及宜家 ...

  8. Atitit orm的实现模式 data-mapper模式和active-record模式有什么区别

    Atitit orm的实现模式  data-mapper模式和active-record模式有什么区别 1.1. 这是来自Node.js路线有关混合两种ORM模式Active Record(活动记录模 ...

  9. crawler_exa1

    编辑中... #! /usr/bin/env python # -*- coding:utf-8 -*- # Author: Tdcqma ''' 网页爬虫,版本 2017-09-20 21:16 ' ...

  10. curl模拟访问已经存在的cookie

    curl 'http://i.meituan.com/brunch/order?status=2' -H 'Pragma: no-cache' -H 'Accept-Encoding: gzip, d ...