使用Laravel Excel快速導出數據到Excel表格

一、項目背景

Laravel是一個流行的PHP框架,它提供了輕鬆構建Web應用程序所需的工具和功能。然而,在某些情況下,我們需要從Web應用程序中導出數據並生成Excel表格,而Laravel框架並沒有這個功能。因此,我們需要使用第三方擴展庫Laravel Excel來快速導出數據到Excel表格。

二、安裝Laravel Excel擴展庫

安裝Laravel Excel非常簡單,只需在終端中執行以下命令:

composer require maatwebsite/excel

當安裝完成後,我們需要向Laravel註冊擴展庫。打開config/app.php文件,在providers數組中添加以下代碼:

'providers' => [
    // ...
    Maatwebsite\Excel\ExcelServiceProvider::class,
]

在aliases數組中也需要添加以下配置代碼:

'aliases' => [
    // ...
    'Excel' => Maatwebsite\Excel\Facades\Excel::class,
]

三、導出Excel表格

1.簡單例子

為了說明如何使用Laravel Excel庫快速導出數據到Excel表格,我們來看一個簡單的例子。首先,我們需要創建一個控制器:

php artisan make:controller ExportController

然後打開ExportController.php文件,添加以下代碼:

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Maatwebsite\Excel\Facades\Excel;

class ExportController extends Controller
{
    public function export()
    {
        $data = [
            ['id' => 1, 'name' => 'John'],
            ['id' => 2, 'name' => 'Jane'],
            ['id' => 3, 'name' => 'Steve'],
            ['id' => 4, 'name' => 'Marius'],
        ];

        return Excel::download(new UsersExport($data), 'users.xlsx');
    }
}

導出的數據保存在$data數組變數中,並且我們將使用Export類將數據導出到Excel文件。最後,我們將文件保存為users.xlsx。我們只需要添加一個按鈕到我們的視圖中,調用export()函數即可實現文件導出:

<a href="{{ route('export') }}">Export</a>

我們需要創建一個Export類,打開終端,執行以下命令:

php artisan make:export UsersExport --model=User

這將創建一個名為UsersExport的類,並在其中添加導出Excel文件所需的函數:

namespace App\Exports;

use App\Models\User;
use Maatwebsite\Excel\Concerns\FromCollection;

class UsersExport implements FromCollection
{
    public function __construct(array $data)
    {
        $this->data = $data;
    }

    public function collection()
    {
        return collect($this->data);
    }
}

現在我們就可以使用以下命令在瀏覽器中運行export()函數,該函數將導出數據並保存到users.xlsx文件中:

php artisan serve

2.增加樣式

我們可以很容易地嚮導出的Excel文件中添加樣式,只需在Export類中添加一個函數即可:

public function headings(): array
{
    return [
        'ID', 'Name'
    ];
}

public function styles(Worksheet $sheet)
{
    $cellRange = 'A1:B1';  // 選擇要設置樣式的範圍
    $sheet->getStyle($cellRange)->applyFromArray([
        'font' => [
            'bold' => true
        ]
    ]);
}

3.使用多個表格

有時,我們需要將多個表格導出到單個Excel文件中。這也很容易實現,只需在Export類中添加另一個函數即可:

namespace App\Exports;

use Illuminate\Support\Collection;
use Maatwebsite\Excel\Concerns\Exportable;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\WithMultipleSheets;

class UsersExport implements FromCollection, WithMultipleSheets
{
    use Exportable;

    protected $data;

    public function __construct(array $data)
    {
        $this->data = $data;
    }

    public function collection()
    {
        return collect($this->data);
    }

    public function sheets(): array
    {
        $sheets = [];

        $sheets[] = new UsersSheet($this->data);
        $sheets[] = new OrdersSheet($this->data);

        return $sheets;
    }
}

class UsersSheet implements FromCollection
{
    public function __construct(array $data)
    {
        $this->data = $data;
    }

    public function collection()
    {
        return collect($this->data);
    }

    public function headings(): array
    {
        return ['ID', 'Name'];
    }
}

class OrdersSheet implements FromCollection
{
    public function __construct(array $data)
    {
        $this->data = $data;
    }

    public function collection()
    {
        return collect($this->data);
    }

    public function headings(): array
    {
        return ['Order ID', 'Amount'];
    }
}

在以上例子中,我們創建了一個名為UsersSheet的類和一個名為OrdersSheet的類,每個類都創建了自己的表格。然後,我們可以使用sheets()函數將它們組合在一起並導出到單個Excel文件中。

四、總結

使用Laravel Excel擴展庫可以輕鬆地將數據導出到Excel表格中,而且也非常容易添加樣式和多個表,非常方便。希望大家可以根據本文提供的方法實踐開發,以便更好的了解和掌握Laravel Excel的應用。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/311015.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2025-01-05 13:23
下一篇 2025-01-05 13:23

相關推薦

  • Python讀取CSV數據畫散點圖

    本文將從以下方面詳細闡述Python讀取CSV文件並畫出散點圖的方法: 一、CSV文件介紹 CSV(Comma-Separated Values)即逗號分隔值,是一種存儲表格數據的…

    編程 2025-04-29
  • Ojlat:一款快速開發Web應用程序的框架

    Ojlat是一款用於快速開發Web應用程序的框架。它的主要特點是高效、易用、可擴展且功能齊全。通過Ojlat,開發人員可以輕鬆地構建出高質量的Web應用程序。本文將從多個方面對Oj…

    編程 2025-04-29
  • Python中讀入csv文件數據的方法用法介紹

    csv是一種常見的數據格式,通常用於存儲小型數據集。Python作為一種廣泛流行的編程語言,內置了許多操作csv文件的庫。本文將從多個方面詳細介紹Python讀入csv文件的方法。…

    編程 2025-04-29
  • 使用Treeview顯示錶格

    在web開發中,顯示錶格數據是一項很常見的需求。當我們需要在頁面上顯示大量數據時,除了使用傳統的表格樣式外,還可以使用Treeview這種可摺疊的表格樣式,以便更好地展示數據。本文…

    編程 2025-04-29
  • 如何用Python統計列表中各數據的方差和標準差

    本文將從多個方面闡述如何使用Python統計列表中各數據的方差和標準差, 並給出詳細的代碼示例。 一、什麼是方差和標準差 方差是衡量數據變異程度的統計指標,它是每個數據值和該數據值…

    編程 2025-04-29
  • Python多線程讀取數據

    本文將詳細介紹多線程讀取數據在Python中的實現方法以及相關知識點。 一、線程和多線程 線程是操作系統調度的最小單位。單線程程序只有一個線程,按照程序從上到下的順序逐行執行。而多…

    編程 2025-04-29
  • Python爬取公交數據

    本文將從以下幾個方面詳細闡述python爬取公交數據的方法: 一、準備工作 1、安裝相關庫 import requests from bs4 import BeautifulSou…

    編程 2025-04-29
  • Python兩張表數據匹配

    本篇文章將詳細闡述如何使用Python將兩張表格中的數據匹配。以下是具體的解決方法。 一、數據匹配的概念 在生活和工作中,我們常常需要對多組數據進行比對和匹配。在數據量較小的情況下…

    編程 2025-04-29
  • Python數據標準差標準化

    本文將為大家詳細講述Python中的數據標準差標準化,以及涉及到的相關知識。 一、什麼是數據標準差標準化 數據標準差標準化是數據處理中的一種方法,通過對數據進行標準差標準化可以將不…

    編程 2025-04-29
  • 如何使用Python讀取CSV數據

    在數據分析、數據挖掘和機器學習等領域,CSV文件是一種非常常見的文件格式。Python作為一種廣泛使用的編程語言,也提供了方便易用的CSV讀取庫。本文將介紹如何使用Python讀取…

    編程 2025-04-29

發表回復

登錄後才能評論