日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 综合教程 >内容正文

综合教程

Laravel Excel3.0如何导出

發(fā)布時(shí)間:2023/12/29 综合教程 33 生活家
生活随笔 收集整理的這篇文章主要介紹了 Laravel Excel3.0如何导出 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

下面由Laravel教程欄目給大家介紹Laravel Excel3.0導(dǎo)出方法,希望對(duì)需要的朋友有所幫助!

導(dǎo)出方法抽離:

<?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 :合并單元格所需參數(shù);
     * $mergeCell 需要合并的位置數(shù)組以MAP形式存儲(chǔ) [開始行=>結(jié)束行]
     * $columnName 需要合并列 與合并行數(shù)結(jié)合使用ARRAY存儲(chǔ) ['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;

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

//輸入數(shù)據(jù)
        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;
    }
}

使用:

/*表頭表體都為二維數(shù)組*/
$row=[['row1'=>'列1','row2'=>'列2']];
/*與表頭key對(duì)應(yīng),缺少數(shù)據(jù)報(bào)錯(cuò)*/
$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"];
/*數(shù)字過(guò)長(zhǎng)的列轉(zhuǎn)換格式防止科學(xué)計(jì)數(shù)*/
$formatNumber=['A','B','C'];
//上方A,B,C列都為示意,根據(jù)自己需求調(diào)整,對(duì)應(yīng)EXCEL的列
return Excel::download(new Export($row,$list,$mergeCell,$columnName,$formatNumber),'fileName');

總結(jié)

以上是生活随笔為你收集整理的Laravel Excel3.0如何导出的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。