0

0

Laravel开发:如何使用Laravel Excel和PHPOffice读写Excel文件?

PHPz

PHPz

发布时间:2023-06-13 17:57:58

|

3105人浏览过

|

来源于php中文网

原创

随着excel文件在商业和财务领域中的广泛使用,将excel文件整合到web应用程序中已经成为开发人员所需的技能之一。由于laravel是一种流行的php框架,其生态系统中有许多包可以帮助我们读写excel文件。本文将介绍如何使用laravel excel和phpoffice库在laravel应用程序中读写excel文件。

什么是Laravel Excel?

Laravel Excel是一个为Laravel框架开发的强大Excel处理工具。该工具提供了易于使用的API,可以帮助我们轻松地导入和导出Excel文件。该工具的一个主要优点是它允许直接操作Excel文件而无需依赖于Excel软件。

安装Laravel Excel可以通过Composer完成。在终端中进入Laravel项目的目录,并运行下面的Composer命令:

composer require maatwebsite/excel

该命令将从Packagist下载最新版本的Laravel Excel并自动完成安装过程。

立即学习PHP免费学习笔记(深入)”;

如何使用Laravel Excel导出Excel文件?

Laravel Excel提供了一个Excel类,它是一个代理类,通过它可以创建新的Excel文件或打开并编辑现有的Excel文件。我们可以使用该类在Laravel应用程序中导出Excel文件。

在项目中创建一个新的Excel文件,我们可以使用Laravel Excel提供的以下模板:

get();
    }
}

在上面的代码中,我们定义了一个名为ExampleExport的类。该类使用FromCollection和WithHeadings接口,这些接口提供了生成Excel文件所需的方法。

在headings()方法中,我们定义了Excel文件的标题,这些标题列在Excel工作表的第一行中。在collect()方法中,我们从数据库中检索用户记录并将其返还给调用该类的控制器。

要导出Excel文件,我们可以在控制器方法中实例化ExampleExport,如下所示:

public function export()
{
    return Excel::download(new ExampleExport, 'users.xlsx');
}

在上面的代码中,我们使用Laravel Excel提供的download()方法从ExampleExport导出一个Excel文件。该方法需要两个参数:第一个参数是ExampleExport实例,第二个参数是Excel文件名。

在浏览器中访问导出方法的URL时,系统将会提示您下载users.xlsx文件。

如何使用Laravel Excel导入Excel文件?

读取Excel文件并将其数据导入数据库时,我们可以使用Laravel Excel提供的import()方法。该方法接受三个参数:文件对象、任务回调和工作表名称。

知识画家
知识画家

AI交互知识生成引擎,一句话生成知识视频、动画和应用

下载

为了演示如何导入Excel文件,我们将创建一个名为UserImport的类,如下所示:

 $row[0],
            'email' => $row[1],
            'phone' => $row[2],
        ]);
    }
}

在上面的代码中,我们使用ToModel接口实现了UserImport类。ToModel接口提供了一个必需的model()方法,该方法将每一行Excel数据转换为模型对象。在上面的代码中,我们解析了Excel文件中的前三个列并将其用于创建新的用户记录。

在控制器中使用import()方法导入Excel文件,如下所示:

public function import(Request $request)
{
    $file = $request->file('file');
    Excel::import(new UserImport, $file);
    return redirect()->back()->with('success', 'Excel file imported successfully.');
}

在上面的代码中,我们获取上传的Excel文件对象并通过Laravel Excel的import()方法将其导入到UserImport类中。如果导入成功,系统将向用户发送带有“Excel文件成功导入”的成功消息的重定向响应。

如何使用PHPOffice库读写Excel文件?

PHPOffice是一个PHP库,用于读写不同类型的办公室文件,如Excel、Word和PowerPoint等。PHPOffice与Laravel Excel不同,它不是为特定的框架开发的,可以用于任何PHP应用程序中。

在安装PHPOffice之前,您需要确保已安装PHP Zip扩展和PHP XML扩展。

使用Composer安装PHPOffice的Spreadsheet库,可以使用以下命令:

composer require phpoffice/phpspreadsheet

要创建一个新的Excel文件,我们可以使用以下代码:

getActiveSheet();
$sheet->setCellValue('A1', 'Hello World!');
$sheet->setCellValue('B1', 'This is PHPOffice.');

$writer = new Xlsx($spreadsheet);
$writer->save('hello.xlsx');

在上面的代码中,我们首先创建一个新的电子表格,并在其第一行的前两个列中添加了“Hello World!”和“This is PHPOffice.”的单元格。然后,我们将电子表格保存到hello.xlsx文件中。

要打开和编辑现有的Excel文件,我们可以使用以下代码:

getActiveSheet();
$sheet->setCellValue('C1', 'This cell has been added.');

$writer = new Xlsx($spreadsheet);
$writer->save('hello.xlsx');

在上面的代码中,我们使用IOFactory类从磁盘加载现有的Excel文件。然后,我们打开了该文件的活动工作表,并向其添加了一个新的单元格。最后,我们将更新保存到原始文件中。

结论

在本文中,我们介绍了如何使用Laravel Excel和PHPOffice库在Laravel应用程序中读写Excel文件。我们学习了如何使用Laravel Excel导出和导入Excel文件,以及如何使用PHPOffice库创建、打开和编辑现有的Excel文件。这些技术应该使您能够更轻松地整合Excel文件到您的Laravel应用程序中。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

12

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

4

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

18

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

19

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

3

2026.01.29

Java空对象相关教程合集
Java空对象相关教程合集

本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 14.5万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号