thinkphp6 整合PhpSpreadsheet 导出数据到excel
web ThinkPHP6 2022-01-15 580 1
关于本站

本人承接php网站维护,病毒查杀,网站编辑,网站改版,html制作

有需要网站维护,改版,病毒查杀,网站编辑,网站备案,html制作等相关的工作可以联系我。
本人有多年相关工作经验,也可提供免费咨询,交个朋友。
有需要探讨问题的朋友,也可以加我微信,共同探讨!
微信:15011482830 QQ:408917339

2462817 1902 22
最新评论
为啥按照你的方法去写完后 提示未定义的hostname?
评 tp6用tp5er实现数据库备份,数据库还原
了解了,应该用超链接去访问 我当时用的是ajax,这回在到你这看看如何用Tp6备份数据库
评 thinkphp6 整合PhpSpreadsheet 导出数据到excel
为什么我执行这个方法 没有下载 ,但用url访问这个页面就可以下载了 是我哪里弄错了吗
评 thinkphp6 整合PhpSpreadsheet 导出数据到excel
:haha:
评 SublimeText3 ctrl+f打开搜索框后怎么关闭?
如果在每个单词下面标上注释和用意就更好了
评 js按大写字母拆分字符串
文章标签更多
ThinkPHP (199)
Mysql (41)
DedeCms (33)
jQuery (45)
证件照 (1)
setInc (4)
setDec (4)
onclick (5)
打开边栏(ESC) 关闭边栏(ESC)

thinkphp6 整合PhpSpreadsheet 导出数据到excel

use PhpOffice\PhpSpreadsheet\Spreadsheet;
 use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
/**根据提交的时间导出数据**/
    public function outdata(){
        $start=strtotime(input('post.outstart')); /**将日期转换成时间戳**/
        $end=strtotime(input('post.outend'));/**将日期转换成时间戳**/
        
        if(empty($start)||empty($end)){ /**如果时间为空 查询所有数据**/
            $data=Db::table('fs_hk666')->order('id desc')->select();
        }else{  /**根据时间查询数据**/
            $data=Db::table('fs_hk666')->whereTime('create_time', 'between', [$start, $end])->order('id desc')->select();/**传递分页参数**/
        }
        
        $spreadsheet = new Spreadsheet();
        $sheet = $spreadsheet->getActiveSheet();
        $sheet->setCellValue('A1', 'id编号');
        $sheet->setCellValue('B1', '姓名');
        $sheet->setCellValue('C1', '手机号码');
        $sheet->setCellValue('D1', '来源');
        $sheet->setCellValue('E1', '来源ip');
        $sheet->setCellValue('F1', '入库时间');
        
        /*--------------开始从数据库提取信息插入Excel表中------------------*/
         $i=2;  //定义一个i变量,目的是在循环输出数据是控制行数
         /*$i = 2,因为第一行是表头,所以写到表格时候只能从第二行开始写。*/
        $count = count($data);  //计算有多少条数据
        for ($i = 2; $i <= $count+1; $i++) {
            $sheet->setCellValue('A' . $i, $data[$i-2]['id']); 
            $sheet->setCellValue('B' . $i, $data[$i-2]['name']); 
            $sheet->setCellValue('C' . $i, $data[$i-2]['mobile']); 
            if($data[$i-2]['status']=='0'){
                $sheet->setCellValue('D' . $i,"电脑");
            }else{
                $sheet->setCellValue('D' . $i,"移动");
            }
            $sheet->setCellValue('E' . $i, $data[$i-2]['from_ip']); 
            $sheet->setCellValue('F' . $i, date('Y-m-d H:i:s',$data[$i-2]['create_time'])); 
        }
        
        
        header('Content-Type: application/vnd.ms-excel');
        header('Content-Disposition: attachment;filename="'.'信息'.'.xlsx"');
        header('Cache-Control: max-age=0');
        $writer = new Xlsx($spreadsheet);
        $writer->save('php://output');
        exit;
    }
composer命令安装phpspreadsheet

composer require phpoffice/phpspreadsheet

版权声明:本篇文章来源于网络。 来源链接

相关推荐
tp6控制器不存在的解决方法:控制器不存在:app\controller\Index
ThinkPHP6 | 2021-12-01 766
当我们下载tp6,应用 多应用模式的时候,提示错误:控制器不存在:app\controller\Index,如图: 原因 多应用没有配置 解决方法 步骤如下: (1)需要安装多应用模式扩展think-multi-app 进入项目根目录。我的路径是(切记改为自己的项目路径):D:\phpStudy\PHPTutorial\...
tp6中间件方法必须返回Response对象实例
ThinkPHP6 | 2021-12-08 720
tp6中间件方法必须返回Response对象实例,错误如图: 解决方法: 根据手册中需要return出去才可以不报错https://www.kancloud.cn/manual/thinkphp6_0/1037493