lumen下操作excel

1、安装excel组件
修改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。

更详细介绍见:[url]http://www.shaoqun.com/a/194775.aspx[/url]

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());
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值