搜索
首页php框架Laravel简析Laravel-excel3.1的基础用法

下面由Laravel教程栏目给大家介绍关于Laravel-excel3.1最基础用法,希望对大家有所帮助!

  • 官网:https://docs.laravel-excel.com

路由定义为GET

Route::get('/export', [OrderController::class, 'export']);

控制器转发

public function export(Request $request): BinaryFileResponse{
     return Excel::download(new OrderExport($request->get('status', -1)), 'order.xlsx');}

业务代码

<?php

namespace App\Exports;

use App\Models\Order;
use Illuminate\Support\Collection;
use Maatwebsite\Excel\Concerns\FromCollection;
use Maatwebsite\Excel\Concerns\WithColumnFormatting;
use Maatwebsite\Excel\Concerns\WithHeadings;
use Maatwebsite\Excel\Concerns\WithMapping;
use PhpOffice\PhpSpreadsheet\Shared\Date;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;

/**
 * 派单导出
 */
class OrderExport implements FromCollection, WithHeadings, WithColumnFormatting, WithMapping
{
    public $status;

    //接受参数
    public function __construct(int $status)
    {
        $this->status = $status;
    }

    /**
     * 数据源
     * @return Collection
     */
    public function collection(): Collection
    {
        $query = Order::query();
        if ($this->status != -1) {
            $query->where(&#39;status&#39;, $this->status);
        }
        return $query->get();
    }

    /**
     * 自定义表头
     * @return string[]
     */
    public function headings(): array
    {
        return [
            &#39;编号&#39;,
            &#39;创建人&#39;,
            &#39;中队长&#39;,
            &#39;人员&#39;,
            &#39;名称&#39;,
            &#39;备注&#39;,
            &#39;状态&#39;,
            &#39;创建时间&#39;,
            &#39;更新时间&#39;
        ];
    }

    /**
     * 设置单元格时间格式
     * @return array
     */
    public function columnFormats(): array
    {
        return [
            &#39;H&#39; => NumberFormat::FORMAT_DATE_YYYYMMDD,
            &#39;I&#39; => NumberFormat::FORMAT_DATE_YYYYMMDD,
        ];
    }

    /**
     * 自定义数据列
     * @param mixed $row
     * @return array
     */
    public function map($row): array
    {
        return [
            $row->id,
            $row->founder->name ?? &#39;无&#39;,
            $row->squadron->name ?? &#39;无&#39;,
            $row->player->name ?? &#39;无&#39;,
            $row->name,
            $row->remark ?: &#39;无&#39;,
            $this->statusMap($row->status),
            Date::dateTimeToExcel($row->created_at),
            Date::dateTimeToExcel($row->updated_at),
        ];
    }

    /**
     * 状态转化
     * @param $status
     * @return string
     */
    public function statusMap($status): string
    {
        switch ($status) {
            case 0:
                $statusText = &#39;待处理&#39;;
                break;
            case 1:
                $statusText = &#39;处理中&#39;;
                break;
            case 2:
                $statusText = &#39;待审核&#39;;
                break;
            case 3:
                $statusText = &#39;已完成&#39;;
                break;
            default:
                $statusText = &#39;未知&#39;;
        }
        return $statusText;
    }
}

相关推荐:最新的五个Laravel视频教程                               

以上是简析Laravel-excel3.1的基础用法的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:learnku。如有侵权,请联系admin@php.cn删除
最新的Laravel版本是什么?最新的Laravel版本是什么?May 09, 2025 am 12:09 AM

截至2023年10月,Laravel的最新版本是10.x。1.Laravel10.x支持PHP8.1,提升了开发效率。2.Jetstream改进支持Livewire和Inertia.js,简化前端开发。3.EloquentORM增加全文搜索功能,提升数据处理性能。4.使用时需注意依赖包兼容性,并应用缓存优化性能。

Laravel迁移:数据库管理初学者指南Laravel迁移:数据库管理初学者指南May 09, 2025 am 12:07 AM

laravelmigrationsStreamLinedAtabasemagementbyByProvideversionControlforyourDatabaseschema.1)他们alloweryoutodefineandsharethertherteructureofyourdatabase,MakeiteAsyTomanageChangEsovertime.2)MigrationalageChangangeSovertime.2)MigrationScancanbeccanCanbeCreateDandRunusingsImplecommands,EnsurnistateTapeve

Laravel迁移:最佳编码指南Laravel迁移:最佳编码指南May 09, 2025 am 12:03 AM

Laravel的迁移系统是开发者进行数据库设计和管理的强大工具。1)确保迁移文件命名清晰明了,使用动词描述操作。2)考虑数据完整性和性能,如为字段添加唯一约束。3)使用事务处理确保数据库一致性。4)在迁移最后创建索引以优化性能。5)保持迁移的原子性,每个文件只包含一个逻辑操作。通过这些实践,可以编写高效、可维护的迁移代码。

最新的Laravel版本:与最新功能保持最新最新的Laravel版本:与最新功能保持最新May 09, 2025 am 12:03 AM

Laravel的最新版本是10.x,发布于2023年初。该版本带来增强的EloquentORM功能和简化的路由系统,提升了开发效率和性能,但升级时需谨慎测试以防引入问题。

掌握Laravel软删除:最佳实践和高级技术掌握Laravel软删除:最佳实践和高级技术May 08, 2025 am 12:25 AM

laravelsoftdeletesallow“删除” withoutremovingRecordSssfromtheDatabase.toimplement:1)usethesoftdeletdeleterationyourmodel.2)usewithtrashed()toincludesoft-deletedrecordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquor sinecustomscopemscopemscopeslikeonlikeOnlikeOnlikeOnlikeOnlikeNiqueniendselline)

Laravel软删除:恢复和永久删除记录Laravel软删除:恢复和永久删除记录May 08, 2025 am 12:24 AM

在Laravel中,恢复被软删除的记录使用restore()方法,永久删除使用forceDelete()方法。1)恢复单个记录使用withTrashed()->find()->restore(),多个记录使用onlyTrashed()->restore()。2)永久删除单个记录使用withTrashed()->find()->forceDelete(),多个记录使用onlyTrashed()->forceDelete()。

当前的Laravel版本:今天下载和升级!当前的Laravel版本:今天下载和升级!May 08, 2025 am 12:22 AM

你应该下载并升级到最新的Laravel版本,因为它提供了增强的EloquentORM功能和新的路由特性,这些更新可以提高应用程序的效率和安全性。要升级,请按照以下步骤:1.备份当前应用程序,2.更新composer.json文件至最新版本,3.运行更新命令。虽然可能会遇到一些常见问题,如废弃函数和包兼容性,但通过参考文档和社区支持,这些问题都可以解决。

Laravel:我什么时候应该更新到最后一个版本?Laravel:我什么时候应该更新到最后一个版本?May 08, 2025 am 12:18 AM

youshouldupdateTothelateStlaravelversionwhentheBeneFitsClearlyOutweighTheCosts.1)newfeaturesandimprovementCanenhanceCarenHanceYourApplication.2)SecurityUpdatesArecrucialifvulnerabilitysareaddresse.3)

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)