Laravel框架 的 Excel 导入 和 导出 (新手踏坑成功)

1. 安装Laravel框架导入导出Excel表扩展: 

                           方法一 : 网速给力,没有发生意外的话使用:composer require maatwebsite/excel

                            方法二:我是用的方式: composer.json 里面的require中添加拓展包:"maatwebsite/excel": "~2.1" 然后运行composer update命令。

  不推荐使用 方法一 进行安装,因为2.1以后的扩展版本 都不支持 laravel框架的 Excel的导入导出,执行方法一的命令是默认安装最新版本(3.1)的扩展插件。 所以推荐使用方法二来手动设置一下版本。 

2.安装后的设置

config/app.php中注册服务提供者到providers数组:

                  Maatwebsite\Excel\ExcelServiceProvider::class,

同样在config/app.php中注册门面到aliases数组:

                 'Excel' => Maatwebsite\Excel\Facades\Excel::class,

如果想要对Laravel Excel进行更多的自定义配置,执行如下Artisan命令:

                      php artisan vendor:publish

执行成功后会在config目录下生成一个配置文件excel.php

然后在routes.php中定义相关路由:

Route::get('excel/export','ExcelController@export');
Route::get('excel/import','ExcelController@import');

(1) 首先实现  比较  简单的  Excel导出:                          

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;

use Excel;  //这里是全局的,可以使用全地址。

class ExcelController extends Controller
{

    public function export(){
        $cellData = [
            ['学号','姓名','成绩'],
            ['10001','AAAAA','99'],
            ['10002','BBBBB','92'],
            ['10003','CCCCC','95'],
            ['10004','DDDDD','89'],
            ['10005','EEEEE','96'],
        ];

/*怎么将自己的数据整理成上边的形式:

$students = Student::where($array)->paginate(10); //分页的形式获取数据。

$cellData = [

['学号','姓名','成绩'],

];

foreach ($students as $student) {

array_push($cellData, [ $student->studentid , $student->name , $student->grade ]);

}

*/ 
       
Excel::create('学生成绩',function($excel) use ($cellData){
            $excel->sheet('score', function($sheet) use ($cellData){
                $sheet->rows($cellData);
            });
        })->export('xls');
    }
}

/*如果还要将该Excel文件保存到服务器上,可以使用store方法:

Excel::create('学生成绩',function($excel) use ($cellData){
     $excel->sheet('score', function($sheet) use ($cellData){
         $sheet->rows($cellData);
     });
})->store('xls')->export('xls'); //文件默认保存到storage/exports目录下.
*/

(1) Excel导入 到 MySQL数据库(需要注意的比较多,坑比较多):

(1)首先配置一下: 无法读取excel中中文表头列数据:修改config目录excel.php的配置文件 :  'to_ascii' => false,

(2)这种方法是:先将本地的Excel表格 保存到 laravel项目下的storage目录下的import.xls文件中,然后再通过Eloquent来操作MySQL数据库:

use Excel ;
public function upload(Request $request){
    $url = $request->file("file")->storeAs('public','import.xls');
    if($url){
        $filePath = "storage/import.xls";
       Excel::load($filePath, function($reader) {
            $data = $reader->all();
            foreach ($data as $item){
                Eloquent表达式 操作 数据库。
            }
        });
    }
}

(3)要创建这个软链,可以使用 Artisan 命令 storage:link :

php artisan storage:link

 

以下是我完整的ExcelController.php控制器代码:

 

<?php

namespace App\Http\Controllers\adminExcel;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;
use Maatwebsite\Excel\Facades\Excel;
use App\Http\Models\Student;
use App\Http\Models\Test_questions;

class ExcelController extends Controller
{
    //导出Excel
    public function export(Request $request)
    {
        /*获取数据start*/
        $collageName = $request->collageName ;
        $progress = $request->progress ;
        $array = array(); //where 查询语句的 条件 数组 。
          if ($collageName != "学院名称" && $collageName !=null) {  //如果collageName 不为 "学院名称" 而且不为 空。
              array_push($array, ['yb_collegename',$collageName]);
          }
        if ($progress !="闯关状态" && $progress != null) {
            if ($progress == 6) {
                array_push($array, ['progress','=',$progress]);
            } else {
                array_push($array, ['progress','<',6]);
            }
        }
        $students = Student::where($array)->paginate(10);
        /*获取数据end*/
  
        $cellData = [
              ['学号','姓名','学院','班级','状态'],
          ];
  
        foreach ($students as $student) {
            $progress = $student->progress == 6 ? "成功" : "未成功" ;
            array_push($cellData, [$student->yb_studentid,$student->yb_realname,$student->yb_collegename,$student->yb_classname,$progress]);
        }
        //打印成 Excel表的形式
        Excel::create('各学院学生闯关统计', function ($excel) use ($cellData) {
            $excel->sheet('score', function ($sheet) use ($cellData) {
                $sheet->rows($cellData);
            });
        })->export('xls');
    }

    //导入Excel表。
    public function upload(Request $request)
    {
        if($request->file("file")==null){
            session()->flash("importNoSuccess", "请添加Excel表格......");
            return redirect()->back();
        }else{

            /**
                这个方法是 自定义文件名 文件上传方法 。 将获取到的Excel文件 保存到storage/app/public/import.xls文件中。
            */
            $url = $request->file("file")->storeAs('public', 'import.xls');
            if ($url) {
                $filePath = "storage/import.xls";
                 
                Excel::load($filePath, function ($reader) {
                    $datas = $reader->all();
                    /**
                        第一行 列名 为  键值对的 键,也就是数组的 索引。 
                    */
                    foreach ($datas as $data) {
                        $title = $data["title"];
                        $a = $data["a"];
                        $b = $data["b"];
                        $c = $data["c"];
                        $d = $data["d"];
                        $right_answer = $data["right_answer"];
                        $type = $data["type"];
                        $newQuestion = Test_questions::create(
                            ["title"=>$title,
                            "A"=>$a,
                            "B"=>$b,
                            "C"=>$c,
                            "D"=>$d,
                            "right_answer"=>$right_answer,
                            "type"=>$type
                            ]
                        );
                    }

                });
            }
            
            session()->flash("importSuccess", "导入题库成功......");
            return redirect()->back();
        }
    }
}

 

参照博客: https://blog.csdn.net/Bepthslowly/article/details/88615572

官方文档:https://laravelacademy.org/post/2024.html/page/5#comments

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Laravel框架实现PHPExcel导入导出功能非常简单。首先,我们需要安装PHPExcel库。可以通过Composer来安装,只需在终端中运行以下命令: ``` composer require phpoffice/phpexcel ``` 安装完成之后,在Laravel的控制器中,我们可以使用PHPExcel的相关类来实现导入导出功能。 要导出Excel文件,我们可以先创建一个PHPExcel对象,并设置一些基本的属性,例如文件名、作者等。然后,我们可以创建一个工作表,并设置一些表头信息。接下来,我们可以遍历需要导出的数据,将数据逐行写入工作表中。最后,我们可以使用PHPExcelWriter将工作表保存为Excel文件。下面是一个示例代码: ```php use PHPExcel; use PHPExcel_IOFactory; class ExportController extends Controller { public function exportData() { $objPHPExcel = new PHPExcel(); // 设置文件属性 $objPHPExcel->getProperties() ->setCreator("Your Name") ->setLastModifiedBy("Your Name") ->setTitle("Export Data") ->setSubject("Export Data") ->setDescription("Export Data"); $objPHPExcel->setActiveSheetIndex(0); $sheet = $objPHPExcel->getActiveSheet(); // 设置表头信息 $sheet->setCellValue('A1', 'Column 1') ->setCellValue('B1', 'Column 2') ->setCellValue('C1', 'Column 3'); // 导出数据 $data = [ ['Data 1', 'Data 2', 'Data 3'], ['Data 4', 'Data 5', 'Data 6'], ]; foreach ($data as $key => $value) { $row = $key + 2; $sheet->setCellValue('A' . $row, $value[0]) ->setCellValue('B' . $row, $value[1]) ->setCellValue('C' . $row, $value[2]); } // 导出Excel $objPHPExcel->getActiveSheet()->setTitle('Sheet 1'); $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007'); $objWriter->save('export.xlsx'); } } ``` 要导入Excel文件,我们可以先创建一个PHPExcel对象,并使用`load`方法加载Excel文件。然后,我们可以通过`getActiveSheet`方法获取工作表,并使用`getCell`方法获取单元格的值。接下来,我们可以遍历工作表的行和列,将数据存储到数组中。最后,我们可以对获取到的数据进行相关的处理。下面是一个示例代码: ```php use PHPExcel; use PHPExcel_IOFactory; class ImportController extends Controller { public function importData() { $objPHPExcel = PHPExcel_IOFactory::load('import.xlsx'); $sheet = $objPHPExcel->getActiveSheet(); $data = []; foreach ($sheet->getRowIterator() as $row) { $rowData = []; foreach ($row->getCellIterator() as $cell) { $rowData[] = $cell->getValue(); } $data[] = $rowData; } // 对导入的数据进行处理 // ... return $data; } } ``` 通过以上的代码,我们就可以轻松地在Laravel框架中实现PHPExcel导入导出功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值