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。

   更详细介绍见: 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());
}

猜你喜欢

转载自sensejw.iteye.com/blog/2293069
今日推荐