laravel 获取数据(laravel读取excel)

2024-12-05 0 188

Laravel 获取数据(Laravel 读取 Excel)

在 Laravel 应用中,读取 Excel 文件是一个常见的需求,尤其是在处理大量数据导入或数据迁移时。介绍如何使用 maatwebsite/excel 包来实现这一功能,并提供多种解决方案。

解决方案

maatwebsite/excel 是一个非常强大的 Laravel 包,用于处理 Excel 文件的读取和写入。通过这个包,我们可以轻松地将 Excel 文件中的数据导入到数据库中,或者从数据库中导出数据到 Excel 文件。如何安装和使用这个包,并提供几个示例代码。

安装 maatwebsite/excel

我们需要通过 Composer 安装 maatwebsite/excel 包。在终端中运行以下命令:

bash
composer require maatwebsite/excel

安装完成后,需要发布配置文件和视图文件:

bash
php artisan vendor:publish --provider="MaatwebsiteExcelExcelServiceProvider"

这将生成一个配置文件 config/excel.php,你可以根据需要对其进行修改。

读取 Excel 文件

基本读取方法

最简单的读取方法是使用 Excel::import 方法。假设我们有一个 Excel 文件 data.xlsx,其中包含用户信息,我们可以通过以下代码将其读取并保存到数据库中:

php
use AppModelsUser;
use MaatwebsiteExcelFacadesExcel;
use AppImportsUsersImport;</p>

<p>// 导入 Excel 文件
Excel::import(new UsersImport, 'data.xlsx');

在这个例子中,UsersImport 是一个导入类,我们需要创建它。在 app/Imports 目录下创建 UsersImport.php 文件:

php
namespace AppImports;</p>

<p>use AppModelsUser;
use MaatwebsiteExcelConcernsToModel;</p>

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

批量插入数据

如果数据量较大,批量插入可以显著提高性能。我们可以在 UsersImport 类中使用 ToCollection 接口来实现批量插入:

php
namespace AppImports;</p>

<p>use AppModelsUser;
use MaatwebsiteExcelConcernsToCollection;
use IlluminateSupportCollection;</p>

<p>class UsersImport implements ToCollection
{
    public function collection(Collection $rows)
    {
        $users = [];</p>

<pre><code>    foreach ($rows as $row) {
        $users[] = [
            'name' => $row[0],
            'email' => $row[1],
            'password' => bcrypt($row[2]),
        ];
    }

    User::insert($users);
}

}

处理表头

有时候 Excel 文件中包含表头,我们可以通过 WithHeadingRow 接口来处理表头:

php
namespace AppImports;</p>

<p>use AppModelsUser;
use MaatwebsiteExcelConcernsToModel;
use MaatwebsiteExcelConcernsWithHeadingRow;</p>

<p>class UsersImport implements ToModel, WithHeadingRow
{
    public function model(array $row)
    {
        return new User([
            'name' => $row['name'],
            'email' => $row['email'],
            'password' => bcrypt($row['password']),
        ]);
    }
}

通过 maatwebsite/excel 包,我们可以在 Laravel 中轻松地读取 Excel 文件并将数据导入到数据库中。基本读取方法、批量插入数据和处理表头的几种常见场景。希望这些示例能帮助你在实际项目中高效地处理 Excel 文件。

Image

1. 本站所有资源来源于用户上传和网络,因此不包含技术服务请大家谅解!如有侵权请邮件联系客服!cheeksyu@vip.qq.com
2. 本站不保证所提供下载的资源的准确性、安全性和完整性,资源仅供下载学习之用!如有链接无法下载、失效或广告,请联系客服处理!
3. 您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源!如用于商业或者非法用途,与本站无关,一切后果请用户自负!
4. 如果您也有好的资源或教程,您可以投稿发布,成功分享后有积分奖励和额外收入!
5.严禁将资源用于任何违法犯罪行为,不得违反国家法律,否则责任自负,一切法律责任与本站无关

源码下载