IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> PHP知识库 -> tp5导出excel多标签,附源码下载 -> 正文阅读

[PHP知识库]tp5导出excel多标签,附源码下载

tp导出excel多标签

优先安装扩展包
composer require phpoffice/phpspreadsheet
代码里引用
use \PhpOffice\PhpSpreadsheet\IOFactory;
use \PhpOffice\PhpSpreadsheet\Spreadsheet;

public function export_all(){
	    $find = Db::name('user_cost_log')->whereTime('price_time','today')->find();
	    if(empty($find)){
	       $this->error('今日数据还没有生成请生成后导出');
	    }
	    //通过班级查询当天订餐人数
		$jc_class = Db::name('jc_class')
	    ->field('jc.id,jc.sid,jc.gid,jc.classname,js.schoolname,jg.gradename')
	    ->alias('jc')
	    ->join('jc_school js','jc.sid = js.id')
	    ->join('jc_grade jg','jc.gid = jg.id')
		->select();
	    foreach($jc_class as $key=>$value){
	       $jc_class[$key]['cost'] = db::name('user_cost_log')
    	    ->field('uc.childname,u.truename,u.mobile,js.schoolname,jg.gradename,jc.classname')
    		->alias('ucl')
    	    ->join('user_child uc','uc.id = ucl.child_id')
    		->join('user u','u.id = uc.parent_id')
    		->join('jc_school js','uc.sid = js.id')
    		->join('jc_grade jg','uc.gid = jg.id')
    		->join('jc_class jc','uc.cid = jc.id')
    		->where('uc.cid',$value['id'])
    	    ->whereTime('ucl.price_time','today')
    	    ->select();
    	    //清除没有订餐数据的班级
    	    if(empty($jc_class[$key]['cost'])){
                unset($jc_class[$key]);
            }
    	}
    	//定义一个新数组
    	$dataarr=[];
    	//设置列表字段标题
        $row1[] = array(
            '0'=>'学生姓名',
            '1'=>'家长姓名',
            '2'=>'联系方式',
            '3'=>'所在学校',
            '4'=>'所在年级',
            '5'=>'所在班级',
        );
        foreach(array_values($jc_class) as $k=>$val){
            //合并大标题
            $dataarr[$k]['title'] = $val['schoolname'].$val['gradename'].$val['classname'];
            //设置对应信息文字
            $dataarr[$k]['info'] = array(
                "学校:" => $val['schoolname'],
                "年级:" => $val['gradename'],
                "班级:" => $val['classname'],
                "配送方:" => '远行餐饮',
                "配送日期:" => date('Y-m-d',time()),
                "配餐量:" => count($val['cost']),
            );
            //数组重新设置key值
            $key_name = [];
            foreach($val['cost'] as $key=>$value){
                $key_name[] = array_values($value);
            }
            //合并为新的数组
            $dataarr[$k]['rows'] = array_merge($row1,$key_name);
        }
        $this->xtexport($dataarr);
	}
	/**
     * 多sheet的导出
     * @author bwy <xxx@xxx.com>
     * @param [type] $data_array
     * @return void
     */
    public  function xtexport($data_array)
    {
        $time = date("Ymd", time());
        $spreadsheet = new Spreadsheet();
        foreach ($data_array as $key => $data) {
            $this->opSheet($spreadsheet,$key,$data);
        }
        header('Content-Type: application/vnd.ms-excel');
        header("Content-Disposition: attachment;filename=".$time.'订餐名单'.".xlsx");
        header('Cache-Control: max-age=0');
        $objWriter = IOFactory::createWriter($spreadsheet, 'Xlsx');
        $objWriter->save('php://output');
        exit;
    }
    /**
     * 处理多sheet
     * @author bwy <xxx@xxx.com>
     * @param [type] $spreadsheet
     * @param [type] $n
     * @param [type] $data
     * @return void
     */
    public  function opSheet($spreadsheet,$n, $data)
    {
        $spreadsheet->createSheet();//创建sheet
        $objActSheet = $spreadsheet->setActiveSheetIndex($n);//设置当前的活动sheet
        $keys = $data['rows'][0];//这是你的数据键名
        $count = count($keys);//计算你所占的列数
        $infoNum = ceil(count($data['info']) / 2);//求k-v值的所占行数
        $infoStart = $infoNum + 2 ;//下面的详细信息的开始行数
        $cellName    = array('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'AA', 'AB', 'AC', 'AD', 'AE', 'AF', 'AG', 'AH', 'AI', 'AJ', 'AK', 'AL', 'AM', 'AN', 'AO', 'AP', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AV', 'AW', 'AX', 'AY', 'AZ');
        $sheet = $spreadsheet->getActiveSheet($n)->setTitle($data['title']);//设置sheet的名称
        $spreadsheet->getActiveSheet($n)->mergeCells('A1:' . $cellName[$count - 1] . '1'); //合并单元格
        $spreadsheet->getActiveSheet($n)->getStyle('A1')->getFont()->setSize(20); //设置title的字体大小
        $spreadsheet->getActiveSheet($n)->getStyle('A1')->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('A')->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('B')->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('C')->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('D')->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('E')->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle('F')->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle("$infoStart")->getAlignment()->setHorizontal(\PhpOffice\PhpSpreadsheet\Style\Alignment::HORIZONTAL_CENTER); //居中
        $spreadsheet->getActiveSheet($n)->getStyle("$infoStart")->getFont()->setBold(true); //标题栏加粗
        $objActSheet->setCellValue('A1', $data['title']); //设置每个sheet中的名称title
        /**
         * 图中最下面的数据信息循环
         */
        foreach ($data['rows'] as $key => $item)
        {
            //循环设置单元格:
            //$key+$infoStart,因为第一行是表头,所以写到表格时   从第数据行开始写
            for ($i = 65; $i < $count + 65; $i++)
            {
                //数字转字母从65开始:
                //$sheet->setCellValue(strtoupper(chr($i)) . ($key + "$infoStart"), $item[[$keys][$i - 65]]);
                $sheet->setCellValue(strtoupper(chr($i)) . ($key+"$infoStart"), $item[$i - 65]);
                $spreadsheet->getActiveSheet($n)->getColumnDimension(strtoupper(chr($i)))->setWidth(20); //固定列宽
            }
        }
        /**
         * 处理图中的中间区 团长名称之类的
         */
        $rowNumber = 1;
        $infoIndex = 0;
        foreach ($data['info'] as $key => $value) {
            if ($infoIndex % 2 == 0) {
                $rowNumber++;
                $infoCellName1 = 'A' . $rowNumber;
                $infoCellMegreRange = 'B' . $rowNumber . ':C' . $rowNumber;
                $infoCellName2 = 'B' . $rowNumber;
            } else {
                $infoCellName1 = 'D' . $rowNumber;
                $infoCellMegreRange = 'E' . $rowNumber . ':F' . $rowNumber;
                $infoCellName2 = 'E' . $rowNumber;
            }
            $spreadsheet->setActiveSheetIndex($n)->setCellValue($infoCellName1, $key);
            $spreadsheet->getActiveSheet($n)->mergeCells($infoCellMegreRange);
            $spreadsheet->setActiveSheetIndex($n)->setCellValue($infoCellName2, $value);
            $infoIndex++;
        }
    }

导出的样式
tp导出excel多标签.zip

  PHP知识库 最新文章
Laravel 下实现 Google 2fa 验证
UUCTF WP
DASCTF10月 web
XAMPP任意命令执行提升权限漏洞(CVE-2020-
[GYCTF2020]Easyphp
iwebsec靶场 代码执行关卡通关笔记
多个线程同步执行,多个线程依次执行,多个
php 没事记录下常用方法 (TP5.1)
php之jwt
2021-09-18
上一篇文章           查看所有文章
加:2021-07-05 20:17:07  更:2021-07-05 20:18:20 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/6 18:23:42-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码