中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Laravel Excel3.0導出的方法

發布時間:2020-12-10 10:30:11 來源:億速云 閱讀:182 作者:小新 欄目:編程語言

這篇文章主要介紹了Laravel Excel3.0導出的方法,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

                                                          

導出方法抽離:

<?php
namespace App\Exports;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\ShouldAutoSize;
use Maatwebsite\Excel\Concerns\WithColumnFormatting;
use Maatwebsite\Excel\Concerns\WithCustomValueBinder;
use Maatwebsite\Excel\Concerns\WithEvents;
use Maatwebsite\Excel\Concerns\WithStrictNullComparison;
use Maatwebsite\Excel\Events\AfterSheet;
use PhpOffice\PhpSpreadsheet\Cell\StringValueBinder;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;

class Export extends StringValueBinder implements FromCollection,
    ShouldAutoSize,WithColumnFormatting,WithCustomValueBinder,WithStrictNullComparison,WithEvents
{
    private $row;
    private $data;
    private $mergeCell;
    private $columnName;
    private $formatNumber;

    /*
     * $mergeCell $columnName :合并單元格所需參數;
     * $mergeCell 需要合并的位置數組以MAP形式存儲 [開始行=>結束行]
     * $columnName 需要合并列 與合并行數結合使用ARRAY存儲 ['A','B']
     */
    public function __construct($row,$data,$mergeCell=null,$columnName=null,$formatNumber=[])
    {
        $this->row = $row;
        $this->data = $data;
        $this->mergeCell = $mergeCell;
        $this->columnName = $columnName;
        $this->formatNumber = $formatNumber;
    }

    public function collection()
    {
        $row = $this->row;
        $data = $this->data;

//設置表頭
        foreach ($row[0] as $key => $value) {
            $key_arr[] = $key;
        }

//輸入數據
        foreach ($data as $key => &$value) {
            $js = [];
            for ($i=0; $i < count($key_arr); $i++) {
                $js = array_merge($js,[ $key_arr[$i] => $value[ $key_arr[$i] ] ]);
            }
            array_push($row, $js);
            unset($val);
        }
        return collect($row);
    }
    public function registerEvents(): array
    {
        // TODO: Implement registerEvents() method.
        if ($this->mergeCell && $this->columnName){
            return [
                AfterSheet::class => function(AfterSheet $event){
                    foreach ($this->columnName as $column){
                        foreach ($this->mergeCell as $key=>$value){
                            $event->sheet->getDelegate()->mergeCells($column.$key.':'.$column.$value);
                        }
                    }
                }
            ];
        }
        return [];
    }

    public function columnFormats(): array{
        $formatNumber = [];
        foreach ($this->formatNumber as $column){
            $formatNumber[$column] = NumberFormat::FORMAT_TEXT;
        }
        return $formatNumber;
    }
}

使用:

/*表頭表體都為二維數組*/
$row=[['row1'=>'列1','row2'=>'列2']];
/*與表頭key對應,缺少數據報錯*/
$list=[['row1'=>'行1列1','row2'=>'行1列2'],['row1'=>'行2列1','row2'=>'行2列2']];
/*將第一行到第三行,第五行到第七行的A,B,C列各自合并*/
$mergeCell=[1=>3,5=>7];
$columnName=["A","B","C"];
/*數字過長的列轉換格式防止科學計數*/
$formatNumber=['A','B','C'];
//上方A,B,C列都為示意,根據自己需求調整,對應EXCEL的列
return Excel::download(new Export($row,$list,$mergeCell,$columnName,$formatNumber),'fileName');

感謝你能夠認真閱讀完這篇文章,希望小編分享Laravel Excel3.0導出的方法內容對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

驻马店市| 石嘴山市| 四子王旗| 陆丰市| 依兰县| 澜沧| 麦盖提县| 壤塘县| 光泽县| 汉沽区| 汉中市| 麻城市| 承德县| 共和县| 修武县| 讷河市| 商丘市| 富民县| 尉犁县| 浮梁县| 巩义市| 泸州市| 福海县| 巴里| 郎溪县| 沅江市| 甘洛县| 弥勒县| 海原县| 山东| 托里县| 和静县| 万山特区| 桐柏县| 高淳县| 瓦房店市| 盖州市| 景东| 重庆市| 忻城县| 崇礼县|