首页 php框架 Laravel Laravel开发:如何使用Laravel Excel导入和导出Excel文件?

Laravel开发:如何使用Laravel Excel导入和导出Excel文件?

Jun 15, 2023 pm 04:13 PM
excel laravel 导入/导出

Laravel开发:如何使用Laravel Excel导入和导出Excel文件?

随着互联网的快速发展,数据的处理越来越重要,特别是在企业的数据管理中。Excel 文件已经成为企业办公的必备工具之一,因为它可以方便地存储、编辑、计算和分析数据。Laravel 是一款被广泛使用的 PHP 框架,而Laravel Excel 是为 Laravel 开发的一个 Excel 文件操作扩展包,它能够轻松地实现 Excel 文件的导入和导出。

本文将为您详细介绍 Laravel Excel 的使用方法。在本文中,我们将学习如何安装 Laravel Excel 并进行 Excel 文件的导入和导出。

一. 安装 Laravel Excel

在终端中通过 Composer 安装 Laravel Excel

composer require maatwebsite/excel
登录后复制

如果您使用的是 Laravel 版本小于 5.5,则需要在config/app.php文件中配置以下两个服务提供者:

MaatwebsiteExcelExcelServiceProvider::class,
登录后复制
'Excel' => MaatwebsiteExcelFacadesExcel::class,
登录后复制

如果您使用的是 Laravel 版本大于或等于 5.5,则无需手动添加服务提供者,这些服务提供者会自动添加到配置中。

在终端中通过 Artisan 命令进行发布:

php artisan vendor:publish --provider="MaatwebsiteExcelExcelServiceProvider"
登录后复制

这将自动生成以下配置文件和模板文件:

config/excel.php
resources/views/vendor/excel
登录后复制

二. 配置 Laravel Excel

配置文件 excel.php 包含了 Laravel Excel 的所有配置选项。这些选项可以直接在 .env 文件中进行定义或在config/excel.php文件中进行配置。以下是所有可能的选项的详细描述。

'default_driver' => 'local',
登录后复制

选项“default_driver”指定要使用的默认 driver ,这里有两种选择:local、ftp。

'cache' => [
    'enabled' => true,
    'driver' => 'laravel',
],
登录后复制

选项“cache”指定缓存选项,缓存可以提高速度,特别是在进行大量数据处理时。当启用缓存时,设置“cache_driver”为“laravel”或“memcached”。

'temp_path' => sys_get_temp_dir(),
登录后复制

选项 temp_path 指定要用于保存临时文件的文件系统路径。

'csv' => [
    'delimiter' => ',',
    'enclosure' => '"',
    'escape_character' => '\',
    'input_encoding' => 'UTF-8',
    'output_encoding' => 'UTF-8',
    'use_bom' => false,
],
登录后复制

选项“csv”允许配置 CSV 导入和导出的选项,主要有以下选项:

delimiter:分隔符,如:逗号,分号,Tab 等等。

enclosure:列的封闭符号。

escape_character:转义符。

input_encoding:输入编码。

output_encoding:输出编码。

use_bom:是否使用 Bom 字节序。

'exports' => [
    'force_resave' => false,
    'ignore_empty' => false,
    'pre_calculate_formulas' => false,
    'maximum_recursion' => 50,
],
登录后复制

选项“exports”允许配置导出选项,主要有以下选项:

force_resave:是否强制进行保存。

ignore_empty:是否忽略空单元格。

pre_calculate_formulas:是否预先计算公式。

maximum_recursion:递归的最大层数。

三. 导出 Excel 文件

Laravel Excel 对 Excel 文件的导出操作提供了很好的支持。接下来我们将演示如何使用 Laravel Excel 进行数据导出。

首先,打开控制器文件,创建一个新的 Excel 文件并导出数据:

<?php

namespace AppHttpControllers;

use MaatwebsiteExcelFacadesExcel;
use AppExportsUsersExport;

class ExportController extends Controller
{
    public function export()
    {
        return Excel::download(new UsersExport, 'users.xlsx');
    }
}
登录后复制

在上面的控制器方法中,我们使用Excel::download()方法创建了一个 Excel 文件。这个方法接受两个参数:

  • 第一个参数 users 将是导出的数据。我们通过创建一个带有 toExcel() 方法的 UsersExport 辅助类来实现数据的导出。
  • 第二个参数是文件名,它是必需的。

UsersExport 文件的内容如下所示:

<?php

namespace AppExports;

use MaatwebsiteExcelConcernsFromCollection;
use AppUser;

class UsersExport implements FromCollection
{
    public function collection()
    {
        return User::select('id', 'name', 'email')->get();
    }
}
登录后复制

这个类需要实现 MaatwebsiteExcelConcernsFromCollection 接口。我们可以看到 FromCollection 返回的是一个集合类,其中 get() 方法将返回该类中存储的所有用户。

这样,我们就完成了 Laravel Excel 的导出操作。

四. 导入 Excel 文件

Laravel Excel 对 Excel 文件的导入操作也提供了非常好的支持。接下来我们将演示如何使用 Laravel Excel 进行 Excel 文件的数据导入。

首先,打开控制器文件,将 Excel 文件中的数据导入数据库:

<?php

namespace AppHttpControllers;

use IlluminateHttpRequest;
use AppImportsUsersImport;

class ImportController extends Controller
{
    public function import(Request $request)
    {
        $file = $request->file('file');
        Excel::import(new UsersImport, $file);
        return redirect('/')->with('success', 'Excel 数据已成功导入!');
    }
}
登录后复制

在上面的控制器方法中,我们使用 Excel::import() 方法导入Excel文件。这个方法接受两个参数:

  • 第一个参数是 UsersImport,它是导入 Excel 文件到数据库中的类。
  • 第二个参数是要导入的 Excel 文件,它包含要导入的数据。

现在,让我们看一下 UsersImport 类:

<?php

namespace AppImports;

use MaatwebsiteExcelConcernsToModel;
use AppUser;

class UsersImport implements ToModel
{
    public function model(array $row)
    {
        return new User([
            'name' => $row[0],
            'email' => $row[1],
            'password' => bcrypt($row[2])
        ]);
    }
}
登录后复制

如您所见,这个类需要实现 MaatwebsiteExcelConcernsToModel 接口,这个接口定义了一个 model() 方法。该方法将被用于确定新用户的属性。

在 model() 方法中,我们使用数组的数据行信息来存储用户的属性。这里我们在Excel文件中假设第1行为用户名,第2行为电子邮箱,第3行为密码。

这就是我们使用 Laravel Excel 进行 Excel 文件的导入和导出的方式。相信您已经了解到了 Laravel Excel 的基本使用方式和一些高级特性。希望这篇文章对您的 Laravel 学习有所帮助。

以上是Laravel开发:如何使用Laravel Excel导入和导出Excel文件?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Laravel和CodeIgniter的最新版本对比 Laravel和CodeIgniter的最新版本对比 Jun 05, 2024 pm 05:29 PM

Laravel9和CodeIgniter4的最新版本提供了更新的特性和改进。Laravel9采用MVC架构,提供数据库迁移、身份验证和模板引擎等功能。CodeIgniter4采用HMVC架构,提供路由、ORM和缓存。在性能方面,Laravel9的基于服务提供者设计模式和CodeIgniter4的轻量级框架使其具有出色的性能。在实际应用中,Laravel9适用于需要灵活性和强大功能的复杂项目,而CodeIgniter4适用于快速开发和小型应用程序。

Laravel 和 CodeIgniter 中数据处理能力的比较如何? Laravel 和 CodeIgniter 中数据处理能力的比较如何? Jun 01, 2024 pm 01:34 PM

比较Laravel和CodeIgniter的数据处理能力:ORM:Laravel使用EloquentORM,提供类对象关系映射,而CodeIgniter使用ActiveRecord,将数据库模型表示为PHP类的子类。查询构建器:Laravel具有灵活的链式查询API,而CodeIgniter的查询构建器更简单,基于数组。数据验证:Laravel提供了一个Validator类,支持自定义验证规则,而CodeIgniter的验证功能内置较少,需要手动编码自定义规则。实战案例:用户注册示例展示了Lar

Laravel 和 CodeIgniter 对于初学者来说哪一个更友好? Laravel 和 CodeIgniter 对于初学者来说哪一个更友好? Jun 05, 2024 pm 07:50 PM

对于初学者来说,CodeIgniter的学习曲线更平缓,功能较少,但涵盖了基本需求。Laravel提供了更广泛的功能集,但学习曲线稍陡。在性能方面,Laravel和CodeIgniter都表现出色。Laravel具有更广泛的文档和活跃的社区支持,而CodeIgniter更简单、轻量级,具有强大的安全功能。在建立博客应用程序的实战案例中,Laravel的EloquentORM简化了数据操作,而CodeIgniter需要更多的手动配置。

Laravel - Artisan 命令 Laravel - Artisan 命令 Aug 27, 2024 am 10:51 AM

Laravel - Artisan 命令 - Laravel 5.7 提供了处理和测试新命令的新方法。它包括测试 artisan 命令的新功能,下面提到了演示?

Laravel和CodeIgniter:哪种框架更适合大型项目? Laravel和CodeIgniter:哪种框架更适合大型项目? Jun 04, 2024 am 09:09 AM

在选择大型项目框架时,Laravel和CodeIgniter各有优势。Laravel针对企业级应用程序而设计,提供模块化设计、依赖项注入和强大的功能集。CodeIgniter是一款轻量级框架,更适合小型到中型项目,强调速度和易用性。对于具有复杂需求和大量用户的大型项目,Laravel的强大功能和可扩展性更合适。而对于简单项目或资源有限的情况下,CodeIgniter的轻量级和快速开发能力则更为理想。

Laravel和CodeIgniter:哪种框架更适合小型项目? Laravel和CodeIgniter:哪种框架更适合小型项目? Jun 04, 2024 pm 05:29 PM

对于小型项目,Laravel适用于大型项目,需要强大的功能和安全性。CodeIgniter适用于非常小的项目,需要轻量级和易用性。

Laravel 和 CodeIgniter 的模板引擎哪一个更好? Laravel 和 CodeIgniter 的模板引擎哪一个更好? Jun 03, 2024 am 11:30 AM

比较了Laravel的Blade和CodeIgniter的Twig模板引擎,根据项目需求和个人偏好进行选择:Blade基于MVC语法,鼓励良好代码组织和模板继承。Twig是第三方库,提供灵活语法、强大过滤器、扩展支持和安全沙箱。

用 3 个 Excel 财务函数解决复杂财务计算 用 3 个 Excel 财务函数解决复杂财务计算 Jul 21, 2024 pm 06:39 PM

原文标题:《这3个Excel财务函数,又是被低估了的函数!》本文作者:小花本文编辑:竺兰最近小花遇到一个有趣的问题,是来自一位老朋友的灵魂发问:怎么在月交年金和民间互保金融中做出选择?这两个理财产品的基本情况如下:月交年金:每月缴纳1000元,年化利率3%,2年期,到期一次性提取本息。互保金融:每月缴纳本金1000元,每月本金均按10%计息,2年期。同一产品共有24人参与,每个月必须有1人领取其他人缴纳的全部本息,领取之后的次月,必须支付100元/月的利息。如何比较这两种理财产品的优劣呢?我们可

See all articles