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

“最难不过坚持”

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

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

7441650 2655 39
最新评论
https://jueru.net/
评 留言
:weixiao:
评 留言
:shuijiao: :weiqu: :zhenbang: :leng:
评 留言
:yiwen: :yiwen: :yiwen: :yiwen:
评 EasySass: could not generate CSS file. See Output panel for details.
这个业务逻辑多少都有点奇怪了,阅读浏览次数增值在新闻详情页的控制器方法里setInc,这怎么还写进模型事件里了。如果非要用onAfterRead也可以,把新闻文章的内容单独分出来一个news_content表,然后把它和news做关联,然后给news_content表的onAfterRead事件做增值处理,这样点进新闻页内查询到文章内容时才会触发它。
评 TP6模型事件-查询后onAfterRead不好用
文章标签更多
ThinkPHP (254)
Mysql (58)
DedeCms (33)
jQuery (67)
证件照 (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 6955
当我们下载tp6,应用 多应用模式的时候,提示错误:控制器不存在:app\controller\Index,如图: 原因 多应用没有配置 解决方法 步骤如下: (1)需要安装多应用模式扩展think-multi-app 进入项目根目录。我的路径是(切记改为自己的项目路径):D:\phpStudy\PHPTutorial\...
TP6模型事件-查询后onAfterRead不好用
ThinkPHP6 | 2022-06-15 5644
TP6模型事件-查询后onAfterRead不好用 比如,我想实现浏览新闻后,浏览次数加1 实现: public static function onAfterRead($news) { $news->read_number += 1; $news->save(); } 运行后,浏览次数加1了,很好,对不对...