导出多个sheet

//ExportMulSheets.php

namespace App\Exports;

use Maatwebsite\Excel\Concerns\Exportable;
use Maatwebsite\Excel\Concerns\WithMultipleSheets;

class ExportMulSheets implements WithMultipleSheets
{
    use Exportable;

    private $size;
    private $myArray;
    private $myHeadings;
    private $sheetNames;
    private $columns;

    public function __construct($size, $myArray, $myHeadings, $sheetNames, $columns)
    {
        $this->size = $size;
        $this->myArray = $myArray;
        $this->myHeadings  = $myHeadings;
        $this->sheetNames = $sheetNames;
        $this->columns = $columns;
    }

    /**
     * @return array
     */
    public function sheets(): array
    {
        $sheets = [];
        for ($i = 0; $i < $this->size; $i++) {
            $sheets[] = new ExportSheet($this->myArray[$i], $this->myHeadings[$i], $this->sheetNames[$i], $this->columns[$i]);
        }
        return $sheets;
    }
}
//ExportSheet.php

namespace App\Exports;

use Maatwebsite\Excel\Concerns\WithHeadings;
use Maatwebsite\Excel\Concerns\FromArray;
use Maatwebsite\Excel\Concerns\WithTitle;
use Maatwebsite\Excel\Concerns\ShouldAutoSize;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;
use Maatwebsite\Excel\Concerns\WithColumnFormatting;

class ExportSheet implements FromArray, WithHeadings, WithTitle, ShouldAutoSize, WithColumnFormatting
{
    private $myArray;
    private $myHeadings;
    private $title;
    private $columns;

    public function __construct($myArray, $myHeadings, $title, $columns = [])
    {
        $this->myArray = $myArray;
        $this->myHeadings = $myHeadings;
        $this->title = $title;
        $this->columns = $columns;
    }

    public function array(): array
    {
        return $this->myArray;
    }

    public function headings(): array
    {
        return $this->myHeadings;
    }

    public function title(): string
    {
        return $this->title;
    }

    public function columnFormats(): array
    {
        return $this->columns;
    }
}

excel导出下载

use App\Exports\ExportMulSheets;
use Excel;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;

$columns = ['F' => NumberFormat::FORMAT_PERCENTAGE_00]; //用于sheet列的格式设定 
$excel = Excel::download(new ExportMulSheets(1, [$data], [$header], [$sheetName], [$columns]), $xlsFileName); 
return $excel;

 

原文地址:http://www.cnblogs.com/caroline2016/p/16905582.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性