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. [ffmpeg] 音频样本

    不仅限于ffmpeg,音频采样所得的PCM都含有三个要素:声道(channel).采样率(sample rate).样本格式(sample format). 声道 当人听到声音时,能对声源进行定位,那 ...

  2. 【NLP】Conditional Language Models

    Language Model estimates the probs that the sequences of words can be a sentence said by a human. Tr ...

  3. CSS3选择器p:nth-child和p:nth-of-type之间的差异

    稍微自己理解了一下,感觉就是:nth-of-type似乎有种族歧视,界限划分很清晰.在同一个国家(父级)中的时候,nth-of-type指认自己人排名,nth-child全都算在内排名,阿T的要求真的 ...

  4. 设置 sql_mode

    MySQL 的 sql_mode 合理设置 sql_mode 是个很容易被忽视的变量,默认值是空值,在这种设置下是可以允许一些非法操作的,比如允许一些非法数据的插入.在生产环境必须将这个值设置为严格模 ...

  5. bzoj 4571: [Scoi2016]美味 (主席树)

    链接:https://www.lydsy.com/JudgeOnline/problem.php?id=4571 题面; 4571: [Scoi2016]美味 Time Limit: 30 Sec   ...

  6. 项目管理——WBS工作分解法

    首先我们要了解什么是WBS工作分解法 工作分解结构(Work Breakdown Structure,简称WBS)跟因数分解是一个原理,就是把一个项目,按一定的原则分解,项目分解成任务,任务再分解成一 ...

  7. Typora使用说明(记录总结)

    目录 区域元素 YAML FONT Matters 菜单 段落 标题 引注 序列 可选序列 代码块 数学块 表格 脚注 水平线 特征元素 链接 超链接 内链接 相关链 URLs 图片 斜体 加粗 删除 ...

  8. ubuntu文件搜索统计

    一.在ubuntu下如何搜索文件 1.特点:快速,但是是模糊查找,例如 找 #whereis mysql 它会把mysql,mysql.ini,mysql.*所在的目录都找出来.我一般的查找都用这条命 ...

  9. SqlServer 语法

    四.            Ranking 排序与排名是我们最为常用的统计方式,比如对班级的学生根据成员进行排名,或者按照成绩高低把学生划分成若干梯队:比如最好成绩的10名学生属于第一梯队,后10名又 ...

  10. 定义Sales_data类型

    Sales_data初步定义如下: struct Sales_data { string bookNo; unsigned units_sold = ; double revenue = 0.0; } ...