thinkphp3.

将PHPExcel下载包放在项目\ThinkPHP\Library\Vendor\PHPExcel
thinkphp5 将PHPExcel下载包放在项目\vendor\PHPExcel (调整后的PHPExcel在文末有下载链接) 在控制器中
use PHPExcel_IOFactory;
use PHPExcel;

在方法中
public function exportData()
{   vendor("PHPExcel.PHPExcel.PHPExcel");
  vendor("PHPExcel.PHPExcel.Writer.Excel5");
  vendor("PHPExcel.PHPExcel.Writer.Excel2007");
  vendor("PHPExcel.PHPExcel.IOFactory");   //导出条件 (以下获取数据的方法是thinkphp3.2,thinkphp5自行调整)
  $status = trim(I('get.status'));
  $starttime = trim(I('get.starttime'));
  $endtime = trim(I('get.endtime'));
  $map = array();   if($status != '' && $status != 0){
    $map['status'] = $status;
  }
  if($starttime != '' && $endtime == ''){
    $map['create_time'] = array('gt', strtotime($starttime.' 00:00:00'));
  }
  if($endtime != '' && $starttime == ''){
    $map['create_time'] = array('lt', strtotime($endtime.' 23:59:59'));
  }
  if($starttime != '' && $endtime != '') {
    $map['create_time'] = array(array('gt', strtotime($starttime.' 00:00:00')), array('lt', strtotime($endtime.' 23:59:59')));
  }
 
  $data = M('order')->where($map)->order('id desc')->select();   $title = '订单列表'.date('YmdHis',time()); //定义文件名   $objPHPExcel = new \PHPExcel();   // 表头
  $objPHPExcel->setActiveSheetIndex(0)
        ->setCellValue('A1', '订单号')
        ->setCellValue('B1', '商品名称')
        ->setCellValue('C1', '支付金额')
        ->setCellValue('D1', '商品数量')
        ->setCellValue('E1', '手机号')
        ->setCellValue('F1', '创建时间')
        ->setCellValue('G1', '支付状态');   foreach($data as $k => $v){
    if($v['status'] == 2){
      $v['status'] = '已支付';
    } else if($v['status'] == 1) {
      $v['status'] = '未支付';
    }
    $v['create_time'] = date('Y-m-d H:i:s',$v['create_time']);
    $objPHPExcel->getActiveSheet(0)->setCellValue('A' . ($k + 2), $v['order_sn']."\t"); //订单号太长无法正常显示,在后面加空格
    $objPHPExcel->getActiveSheet(0)->setCellValue('B' . ($k + 2), $v['title']);
    $objPHPExcel->getActiveSheet(0)->setCellValue('C' . ($k + 2), $v['money']);
    $objPHPExcel->getActiveSheet(0)->setCellValue('D' . ($k + 2), $v['num']);
    $objPHPExcel->getActiveSheet(0)->setCellValue('E' . ($k + 2), $v['phone']);
    $objPHPExcel->getActiveSheet(0)->setCellValue('F' . ($k + 2), $v['create_time']);
    $objPHPExcel->getActiveSheet(0)->setCellValue('G' . ($k + 2), $v['status']);
  }   //设置excel单元格的宽
  $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('A')->setWidth(30);
  $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('B')->setWidth(20);
  $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('C')->setWidth(10);
  $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('D')->setWidth(20);
  $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('E')->setWidth(20);
  $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('F')->setWidth(25);
  $objPHPExcel->setActiveSheetIndex(0)->getColumnDimension('G')->setWidth(10);   $objPHPExcel->getActiveSheet()->setTitle($title); //设置sheet的名称
  $objPHPExcel->setActiveSheetIndex(0); //设置sheet的起始位置
  $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); //通过PHPExcel_IOFactory的写函数将上面数据写出来
  $PHPWriter = \PHPExcel_IOFactory::createWriter( $objPHPExcel,"Excel2007");
  header('Content-Type: application/vnd.ms-excel');
  header('Content-Disposition: attachment;filename="'.$title.'.xlsx"');
  header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
  $PHPWriter->save("php://output"); //表示在$path路径下面生成demo.xlsx文件
  exit;
}

 点击PHPExcel下载链接

thinkphp使用PHPExcel导出的更多相关文章

  1. ThinkPhp 使用PhpExcel导出导入多语言文件

    在ThinkPHP 里已经实现了多语言功能,只要在指定的目录下创建对应的语言文件并填充内容,即可实现多语言功能 而多语言的翻译却是一个很麻烦的事情,因为客户特定的行业问题导致我们翻译可能是不准确的 于 ...

  2. Thinkphp解决phpExcel导出数据量大导致内存溢出

    工作需要导出几万的数据量.操作比较频繁.之前数据在七八千是数据导出很慢.phpExcel是方便但是性能一般.现在改为使用csv导出数据:可以缓解内存压力,一次导出两三万是没问题的.当然服务器内存给力, ...

  3. ThinkPHP使用PHPExcel实现Excel数据导入导出完整实例

    这篇文章主要介绍了ThinkPHP使用PHPExcel实现Excel数据导入导出,非常实用的功能,需要的朋友可以参考下 本文所述实例是使用在Thinkphp的开发框架上,要是使用在其他框架也是同样的方 ...

  4. THINKPHP扩展PHPEXCEL,PHP7.2以上版本无法导出Excel

     THINKPHP扩展PHPEXCEL与PHP7.3高版本兼容问题 框架:THINKPHP5,PHPEXCEL版本:1.81 无法导出EXCEL原因为Shared/OLE.php第290行使用cont ...

  5. PHPExcel导出excel文件

    今天园子刚开,先来个货顶下,后续园丁qing我会再慢慢种园子的,希望大家多来园子逛逛. PHPExcel导出excel文件,先说下重要的参数要记住的东西 impUser() 导入方法 exportEx ...

  6. phpExcel导出excel加超级链接的实例代码[转]

    phpexcel实现的导出excel文件的代码,且可以在excel文件中加入超级链接. 说明:PHPExcel的开发包Tests目录有详细使用实例.以下代码支持中文,注意文件编码,文件保存为utf-8 ...

  7. 利用PHPExcel导出excel 以及利用js导出excel

    导出excel的方法output_excel需要依赖PHPExcel 导出csv的方法csv_export不需要 <?php /** * @author ttt */ class ExcelCo ...

  8. php利用phpexcel导出数据

    php中利用phpexcel导出数据的实现代码.对phpexcel类库不熟悉的朋友,可以阅读下<phpexcel中文帮助手册>中的内容,具体实例大家可以phpexcel快速开发指南中的相关 ...

  9. 关于PHPExcel 导出下载表格,调试器响应乱码

    PHPExcel导出表格是日常程序开发很常见的一功能,有些小伙伴千辛万苦把代码写好之后,运行一下结果发现浏览器没反应,表格下载不了或者表格乱码!!!像这种情况有三种解决方法: 1.在header 之前 ...

随机推荐

  1. Jenkins与sonar扫描的集成问题

    记录本周遇到的头疼了很久的一个问题,由于公司需要使用jenkins来自动管理构建项目,然后在关联sonar对项目代码质量进行审核. 接着坑爹的问题来了,原有的技术手段为项目构建成功后通过jenkins ...

  2. 支付宝支付demo(亲测)

    支付宝支付demo 这个是java后台调起支付的demo,直接将body返回给安卓端即可调起支付 package com.dyy.test; import java.text.SimpleDateFo ...

  3. java 从指定行读文件,执行系统命令

    import java.util.*; import java.io.*; public class Example { public static void main(String[] args){ ...

  4. 安卓微信连接fiddler等抓包工具无法抓取https

    问题描述: 在手机连接pc的fiddler后,安卓微信打不开https页面,安卓的浏览器.qq等都可以正常访问https,ios也都可以,就只有安卓微信放问https是空白页面 解决思路: 一. 证书 ...

  5. 走进Java中的持有对象(容器类)之一 容器分类

    Java容器可以说是增强程序员编程能力的基本工具,本系列将带您深入理解容器类. 容器的用途 如果对象的数量与生命周期都是固定的,自然我们也就不需要很复杂的数据结构. 我们可以通过创建引用来持有对象,如 ...

  6. python操作文件练习,配置haproxy

    在使用python操作文件的时候,特别是对于网络设备,通常操作配置文件,会简化配置量,配置文件加载到内存中,运行时使用的是内存中的配置,内存中配置修改后立即生效,如果不将配置内容保存到硬盘中,则下次重 ...

  7. 第三节:框架前期准备篇之利用Newtonsoft.Json改造MVC默认的JsonResult

    一. 背景 在MVC框架中,我们可能经常会用到 return Json(),而Json方法内部又是一个JsonResult类,那么JsonResult内部又是什么原理呢?在MVC框架中,各种xxxRe ...

  8. 17、 利用扇贝网:https://www.shanbay.com/, 做个测单词的小工具。

    先说下,我可以说完全没有看题目要求,我只看了下扇贝网的单词测试工具就开始编码了,写出来的代码尽可能的模仿了网站上的效果. 因为把问题搞复杂了,在这个练习上耽误了很长时间,最后都不想写了,所以代码有些混 ...

  9. WPS for Linux 2017版+字库安装

    一.下载地址: http://wps-community.org/download.html WPS Office for Linux Alpha21[2017-06-15] http://wps-c ...

  10. 【Java编程思想笔记】注解--元注解

    参考文章:(小白的小小白的白 )https://blog.csdn.net/weixin_42315600/article/details/80630669 https://www.cnblogs.c ...