修改composer.json,在require中增加下面的语句,并执行composer update
"maatwebsite/excel": "~2.0.0",
2、注册Excel服务
修改bootstrap/app.php
$app->register(Maatwebsite\Excel\ExcelServiceProvider::class); class_alias('Maatwebsite\Excel\Facades\Excel', 'Excel');
3、修改vendor/maatwebsite/excel/src/maatwebsite/excel中ExcelServiceProvider.php文件
a、注释boot方法中44-46行代码,config_path在lumen中已经移除。
b、修改bindWriters方法中160行代码又原来的Response改成Illuminate\Support\Facades\Response。
更详细介绍见: http://www.shaoqun.com/a/194775.aspx
4、读写excel文件
try { // 获得excel文件输入流,load参数为绝对地址 $reader = Excel::load($params['file']); if (!$reader) { throw new \Exception(1001, '读取导入文件失败'); } $returnresult = array(); // 获得第一个sheet的输入流 $reader = $reader->getSheet(0); // 将内容转为数组 $results = $reader->toArray(); if (count($results) > 1) { // 数组第一行是标题(根据文档实际情况) $title = $results[0]; for ($i = 1; $i < count($results); $i++) { // 获取第N行数据 $row = $results[$i]; // 获取第N行第1个cell $name = $row[0]; // 获取第N行第2个cell $mobile = $row[1]; // 处理数据 ………… ………… // 将处理后的结果保存到结果数组 $returnresult[] = $row; } // 创建一个excel输入文件,文件默认保存地址为storage/exports Excel::create('batchaddclient/' . $task['taskno'], function ($excel) use ($returnresult) { // 将结果数组写入第1个sheet $excel->sheet('score', function ($sheet) use ($returnresult) { $sheet->rows($returnresult); }); // 以excel形式输出文件 })->store('xls'); } else { throw new \Exception(1002, '空的导入文件'); } } catch (\Exception $e){ app('log')->debug($e->getCode() . ',' . $e->getMessage()); }