stephen / chunk-export
There is no license information available for the latest version (1.0.1) of this package.
A simple chunk export
1.0.1
2017-09-22 02:30 UTC
This package is auto-updated.
Last update: 2025-06-19 12:01:40 UTC
README
项目中涉及到大数据量的导出的时候,使用传统的页面导出方式很容易导出内存溢出,通常情况下采用分页导出的方式,循环去读取数据,输出到缓存区
环境要求
1.Laravel 5.1以上
2.PHP5.6以上
安装package
这是一个标准的 Composer 的包,你可以直接通过下面的命令行来安装:
composer require stephen/chunk-export
或者在你的 composer.json 文件中添加:
"stephen/chunk-export" : "~1.0.0" 然后执行 composer install
配置
註冊Service Provider
在config/app.php中添加provider
'providers' => [
\Stephen\Chunk\ChunkServiceProvier::class,
],
在laravel中使用案例
<?php
namespace App\Http\Controllers;
use App\User;
use Illuminate\Http\Request;
use Stephen\Chunk\Service\ChunkService;
class Export extends Controller
{
//
/**
* @var ChunkService
*/
private $chunkService;
/**
* @var User
*/
private $user;
/**
* Export constructor.
* @param ChunkService $chunkService
*/
public function __construct(ChunkService $chunkService, User $user)
{
$this->chunkService = $chunkService;
$this->user = $user;
}
public function index()
{
$config['models'] = $this->user->select('id', 'name', 'email')->orderBy('id', 'DESC');
$config['headers'] = ['姓名', '邮箱'];
$config['filename'] = '用户信息.csv';
$pageSize = 10;
$callback = function ($user) {
$output = [];
$output['name'] = iconv('UTF-8', 'GBK', $user['name']);
$output['email'] = iconv('UTF-8', 'GBK', $user['email']);
return $output;
};
$this->chunkService->exportCsv($config, $callback, $pageSize);
}
}