Maison > cadre php > Laravel > Connaissez-vous ces cinq fonctions de Laravel Excel ?

Connaissez-vous ces cinq fonctions de Laravel Excel ?

藏色散人
Libérer: 2021-12-16 15:11:49
avant
4308 Les gens l'ont consulté

1. Importez des données depuis HTML ou Blade

Supposons qu'il existe déjà un tableau HTML

Connaissez-vous ces cinq fonctions de Laravel Excel ?code de modèle--resources/views/customers/table.blade.php:

Copier après la connexion
                                                                                   @foreach ($customers as $customer)                                                                     @endforeach     
First nameLast nameEmailCreated atUpdated at
{{ $customer->id }}{{ $customer->first_name }}{{ $customer->last_name }}{{ $customer->email }}{{ $customer->created_at }}{{ $customer->updated_at }}

Vous pouvez l'utiliser pour répéter le importer Transférer ce tableau vers Excel

Étape 1. Générer une classe d'exportation

php artisan make:export CustomersFromView --model=Customer
Copier après la connexion

Étape 2. Utiliser FromView pour opérer

namespace App\Exports;

use App\Customer;
use Illuminate\Contracts\View\View;
use Maatwebsite\Excel\Concerns\FromView;

class CustomersExportView implements FromView
{
    public function view(): View
    {
        return view('customers.table', [
            'customers' => Customer::orderBy('id', 'desc')->take(100)->get()
        ]);
    }
}
Copier après la connexion

Voici le fichier Excel importé :

Connaissez-vous ces cinq fonctions de Laravel Excel ?Remarque : Seuls les tableaux HTML peuvent être exportés ici et ne peut pas avoir de balises, telles que html, body, p, etc.

2. Exporter vers des fichiers PDF, HTML ou autres formats

Bien que le nom du package soit Laravel Excel, il fournit une variété de formats d'exportation et est très simple à utiliser. :

return Excel::download(new CustomersExport(), 'customers.xlsx', 'Html');
Copier après la connexion

Par exemple, si vous faites cela, il sera exporté au format HTML, comme indiqué ci-dessous :

Connaissez-vous ces cinq fonctions de Laravel Excel ? Voici le code source :

Connaissez-vous ces cinq fonctions de Laravel Excel ? Pas seulement ça, il. peut également être exporté au format PDF, vous pouvez même choisir parmi trois bibliothèques. La méthode d'utilisation est la même. Il vous suffit de spécifier le format dans le dernier paramètre. Exemple de document :

Connaissez-vous ces cinq fonctions de Laravel Excel ?Remarque : Vous devez installer le package PDF spécifié via Composer, tel que :

composer require dompdf/dompdf
Copier après la connexion

Le PDF exporté est le suivant :

Connaissez-vous ces cinq fonctions de Laravel Excel ?

3. Formatez les cellules selon vos besoins

Laravel Excel. est un "papa" puissant -- PhpSpreadsheet. Il a donc diverses fonctions sous-jacentes, notamment diverses méthodes de formatage des cellules.

Voici un exemple de la façon de l'utiliser dans une classe Laravel Export, telle que app/Exports/CustomersExportStyling.php :

Étape 1. Introduisez la classe appropriée dans l'en-tête.

use Maatwebsite\Excel\Concerns\WithEvents;
use Maatwebsite\Excel\Events\AfterSheet;
Copier après la connexion

Étape 2. Utilisez l'interface WithEvents dans la section des outils.

class CustomersExportStyling implements FromCollection, WithEvents
{
    // ...
Copier après la connexion

Étape 3. Utilisez l'événement AfterSheet pour créer la méthode registerEvents().

/**
 * @return array
 */
public function registerEvents(): array
{
    return [
        AfterSheet::class    => function(AfterSheet $event) {
            // ... 此处你可以任意格式化
        },
    ];
}
Copier après la connexion

Voici un exemple :

/**
 * @return array
 */
public function registerEvents(): array
{
    return [
        AfterSheet::class    => function(AfterSheet $event) {
            // 所有表头-设置字体为14
            $cellRange = 'A1:W1';
            $event->sheet->getDelegate()->getStyle($cellRange)->getFont()->setSize(14);

            // 将样式数组应用于B2:G8范围单元格
            $styleArray = [
                'borders' => [
                    'outline' => [
                        'borderStyle' => \PhpOffice\PhpSpreadsheet\Style\Border::BORDER_THICK,
                        'color' => ['argb' => 'FFFF0000'],
                    ]
                ]
            ];
            $event->sheet->getDelegate()->getStyle('B2:G8')->applyFromArray($styleArray);

            // 将第一行行高设置为20
            $event->sheet->getDelegate()->getRowDimension(1)->setRowHeight(20);

            // 设置 A1:D4 范围内文本自动换行
            $event->sheet->getDelegate()->getStyle('A1:D4')
                ->getAlignment()->setWrapText(true);
        },
    ];
}
Copier après la connexion

Les résultats de ces exemples "aléatoires" sont présentés ci-dessous :

Connaissez-vous ces cinq fonctions de Laravel Excel ?Vous pouvez trouver tous les exemples ci-dessus et d'autres dans la page Recettes de la documentation PhpSpreadsheet.

4. Propriétés du modèle cachées

Supposons que nous ayons créé la table users par défaut de Laravel 5.7 :

Connaissez-vous ces cinq fonctions de Laravel Excel ?Laravel 5.7默认的users表:

Connaissez-vous ces cinq fonctions de Laravel Excel ?

现在我们尝试用简单的FromCollection来导出用户表数据:

class UsersExport implements FromCollection
{
    public function collection()
    {
        return User::all();
    }
}
Copier après la connexion

在导出的Excel 里,你只能看到如下字段,但是没有passwordremember_token

Connaissez-vous ces cinq fonctions de Laravel Excel ?

这是因为在User模型里定义了隐藏字段的属性:

class User extends Authenticatable
{
    // ...

    /**
     * 这个数组用来定义需要隐藏的字段。
     *
     * @var array
     */
    protected $hidden = [
        'password', 'remember_token',
    ];
}
Copier après la connexion

所以,默认情况下这些字段是隐藏的,如果你想在导出数据的时候某些字段不被导出的话,可以直接在模型中定义隐藏属性$hidden


5. 公式

出于某种原因,Laravel Excel 包的官方文档中并没有提及公式,但是这是Excel 重要的功能!

幸运的是,我们可以直接将公式写在导出数据的类中,我们需要设置cell 的值,就像这样:=A2+1 or SUM(A1:A10)

其中一种方式就是实现WithMapping

Maintenant, nous essayons d'utiliser un simple FromCollection pour exporter les données de la table utilisateur :

use App\Customer;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\WithMapping;

class CustomersExportFormulas implements FromCollection, WithMapping
{
    public function collection()
    {
        return Customer::all();
    }

    /**
     * @var Customer $customer
     * @return array
     */
    public function map($customer): array
    {
        return [
            $customer->id,
            '=A2+1',
            $customer->first_name,
            $customer->last_name,
            $customer->email,
        ];
    }
}
Copier après la connexion
Dans l'Excel exporté, vous ne pouvez voir que les champs suivants, mais il n'y a pas de mot de passe ni de remember_token :

Connaissez-vous ces cinq fonctions de Laravel Excel ?🎜🎜Cela est dû au fait que l'attribut de champ caché est défini dans le modèle Utilisateur : 🎜rrreee 🎜Donc, ces champs sont masqués par défaut. Si vous souhaitez que certains champs ne soient pas exportés lors de l'export des données, vous pouvez définir directement l'attribut caché $hidden dans le modèle. 🎜🎜🎜5. Formules🎜🎜Pour une raison quelconque, les formules ne sont pas mentionnées dans la documentation officielle du package Laravel Excel, mais c'est une fonctionnalité importante d'Excel ! 🎜🎜Heureusement, nous pouvons écrire la formule directement dans la classe qui exporte les données. Nous devons définir la valeur de cell, comme ceci : =A2+1 ou SUM(A1:A10). ). 🎜🎜Une solution consiste à implémenter l'interface WithMapping : 🎜rrreee🎜Ci-dessus sont cinq fonctions peu connues de Laravel Excel. 🎜🎜Si vous voulez en savoir plus, j'ai un ensemble de tutoriels en ligne sur l'Export/Import Excel dans Laravel, allez y jeter un oeil !🎜

Adresse originale : https://laravel-news.com/five-hidden-features-of-the-laravel-excel-package

Adresse de traduction : https://learnku.com/laravel/t/24161

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:learnku.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal