Laravel 개발자는 보고 또는 분석을 위해 데이터를 CSV 파일로 내보내야 하는 경우가 많습니다. 이 기사에서는 대규모 데이터 세트에서 최적의 성능을 위해 Laravel의 청킹 및 PHP의 fputcsv
기능을 활용하여 Laravel CSV 내보내기 명령을 생성하는 효율적이고 간단한 방법을 제시합니다.
이 접근 방식은 다음과 같은 몇 가지 주요 이점을 제공합니다.
fputcsv
은 직접적인 CSV 형식을 제공하므로 외부 라이브러리가 필요하지 않습니다.다음 코드는 간결한 CSV 내보내기를 보여줍니다.
<code class="language-php">use Illuminate\Database\Eloquent\Collection; $chunkSize = 500; // Adjustable chunk size $outputStream = fopen('php://stdout', 'wb+'); // Output stream to stdout // Write CSV header row fputcsv($outputStream, ['email', 'name']); // Chunk-based data processing and export User::select(['email', 'name']) ->chunk($chunkSize, function (Collection $users) use ($outputStream) { $users->each(function ($user) use ($outputStream) { fputcsv($outputStream, [$user->email, $user->name]); }); });</code>
$chunkSize = 500;
: 청크당 처리되는 레코드 수를 설정합니다. 데이터 볼륨과 서버 리소스에 따라 필요에 따라 조정하세요.
$outputStream = fopen('php://stdout', 'wb ');
: 쓰기 바이너리 스트림을 표준 출력(stdout
)으로 엽니다. 이를 통해 출력을 파일이나 다른 프로세스로 직접 파이핑할 수 있습니다.
fputcsv($outputStream, ['email', 'name']);
: CSV 헤더 행을 작성합니다.
User::select(['email', 'name'])->chunk($chunkSize, ...);
: Laravel의 chunk
메소드는 User
레코드 덩어리로 $chunkSize
모델 데이터를 처리합니다. chunk
내의 익명 함수가 각 청크를 처리합니다.
$users->each(function ($user) use ($outputStream) { ... });
: 청크의 각 사용자를 반복하고 fputcsv
을 사용하여 이메일과 이름을 CSV에 씁니다.
재사용 가능한 Artisan 명령을 생성하려면 다음과 같이 코드를 구성하세요.
<code class="language-php"><?php namespace App\Console\Commands; use Illuminate\Console\Command; use Illuminate\Database\Eloquent\Collection; use App\Models\User; class ExportUsersToCsv extends Command { protected $signature = 'export:users'; protected $description = 'Export users to CSV'; public function handle() { // ... (Code from previous example) ... } }</code>
내보내기를 실행하는 Artisan 명령php artisan export:users
이 생성됩니다.
이 방법은 최적의 성능과 구현 용이성을 위해 내장된 기능을 활용하여 Laravel에서 CSV 내보내기를 위한 효율적이고 확장 가능한 솔루션을 제공합니다. 특정 요구 사항에 따라 $chunkSize
변수를 조정하는 것을 잊지 마세요.
위 내용은 Laravel에서 빠른 CSV 내보내기 명령 작성의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!