Thinkphp phpexcel导出表格

11 篇文章 0 订阅

一、下载phpexcel插件

composer require phpoffice/phpexcel

二、实例

<?php
//查询数据库(可以加where条件筛选一下)
 $data = $this->getList();
 $arr = array();
 $foreach ($data['list']['data'] as $index => $item){
    $arr[$index]['member_name'] = $item['member_name'];
    $arr[$index]['company_name'] = $item['company_name'];
    $arr[$index]['content'] = $item['content'];
    $arr[$index]['start_time'] = $item['s_time'];
    $arr[$index]['end_time'] = $item['n_time'];

    $arr[$index]['type'] = $item['type_name'];
    $arr[$index]['state'] = $item['state_name'];
    $arr[$index]['pin_time'] = $item['p_time'];

     }


    $title = '请假_' . date('Y-m-d');
    $field = array(
            'A' => array('company_name', '所属单位',15),##字段,表格头,单元格长度
            'B' => array('member_name', '请假人',15),
            'C' => array('type', '请假类型',15),
            'D' => array('state', '状态',15),
            'E' => array('start_time', '开始时间',15),
            'F' => array('end_time', '结束时间',15),
            'G' => array('pin_time', '销假时间',15),
            'H' => array('content', '请假原因',30),
            //导出表格标题设置,key和数据库查询的字段对应
    );

   ob_end_clean();

   $objPHPExcel = new \PHPExcel();
  $objWriter = new \PHPExcel_Writer_Excel2007($objPHPExcel); //设置保存版本格式
  foreach ($arr as $key => $value) {
      foreach ($field as $k => $v) {
          
         $objPHPExcel->getActiveSheet()->getColumnDimension($k)->setWidth($v[2]);
            if ($key == 0) {
                $objPHPExcel->getActiveSheet()->setCellValue($k . '1', $v[1]);
              }
             $i = $key + 2; //表格是从2开始的
              $objPHPExcel->getActiveSheet()->setCellValue($k . $i, $value[$v[0]]);
         }
  }

   header("Pragma: public");
   header("Expires: 0");
   header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
   header("Content-Type:application/force-download");
   header("Content-Type:application/vnd.ms-execl");
   header("Content-Type:application/octet-stream");
   header("Content-Type:application/download");;
   header('Content-Disposition:attachment;filename='.$title.'.xls');
   header("Content-Transfer-Encoding:binary");
   $objWriter->save('php://output');

三、总结

 直接使用,按照以上实例根据自己实际导出数据,方法还是挺简单的,一般没什么复杂的逻辑性处理的导出都可以使用

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杰姆小生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值