bayareawebpro / laravel-simple-csv
A simple CSV importer/ exporter for Laravel.
Package info
github.com/bayareawebpro/laravel-simple-csv
pkg:composer/bayareawebpro/laravel-simple-csv
Requires
- php: ^8.2
- illuminate/support: ^12.0|^13.0
Requires (Dev)
- larastan/larastan: ^2.0|^3.0
- orchestra/testbench: ^10.0|^11.0
- phpunit/phpunit: ^11.0|^12.0
README
https://packagist.org/packages/bayareawebpro/laravel-simple-csv
Features
- Import to LazyCollection.
- Export from Collection, LazyCollection, Generator, Array, Iterable.
- Low(er) Memory Consumption by use of Generators.
Installation
Require the package and Laravel will Auto-Discover the Service Provider.
composer require bayareawebpro/laravel-simple-csv
Publish Config
Publish the config file to customize the default behavior.
artisan vendor:publish --tag=simple-csv
Import Usage
use BayAreaWebPro\SimpleCsv\SimpleCsv; $lazyCollection = SimpleCsv::import(storage_path('collection.csv'));
Formatting Casts
Invokable classes can be passed to the import method allowing you to customize how each row is processed.
use BayAreaWebPro\SimpleCsv\SimpleCsv; use App\SimpleCsv\MyCustomCast; $lazyCollection = SimpleCsv::import(storage_path('collection.csv'), [ MyCustomCast::class ]);
Default Casts
Two cast classes to handle numerics and null values are configured by default and can be overridden in the config file. Casts passed to the import method will be merged with defaults.
use BayAreaWebPro\SimpleCsv\Casts\NumericValues; use BayAreaWebPro\SimpleCsv\Casts\EmptyValuesToNull;
Example Cast Class
You can typehint required dependencies in a constructor method when required.
<?php declare(strict_types=1); namespace App\Csv\Casts; use Carbon\Carbon; use Illuminate\Config\Repository; class ParseTimestamps { /** * Inject services by adding a constructor. */ public function __construct(public Repository $config) { // } /** * Invoked for each row. */ public function __invoke(array $item): array { foreach ($item as $key => $value){ if(in_array($key, ['created_at', 'updated_at'])){ $item[$key] = Carbon::parse($value); } } return $item; } }
Export Usage
use BayAreaWebPro\SimpleCsv\SimpleCsv; // Collection SimpleCsv::export( items: Collection::make(...), path: storage_path('collection.csv') ); // LazyCollection SimpleCsv::export( items: LazyCollection::make(...), path: storage_path('collection.csv') ); // Generator (Cursor) SimpleCsv::export( items: User::query()->where(...)->limit(500)->cursor(), path: storage_path('collection.csv') ); // Array SimpleCsv::export( items: [...], path: storage_path('collection.csv') );
Download Stream
You can simply return the service from a route to create a steamed download.
Optional response headers can be passed as the 3rd argument.
use BayAreaWebPro\SimpleCsv\SimpleCsv; use Symfony\Component\HttpFoundation\StreamedResponse; public function download(): StreamedResponse { return SimpleCsv::download( items: [...], fileName: 'download.csv', headers: ['My-Response-Header' => 'some-value'] ); }
File Splitting Utility
A file splitting utility has been included that will break large CSV files into chunks (while retaining column headers) which you can move/delete after importing. This can help with automating the import of large data sets.
Tip: Find your Bash Shell Binary Path: which sh
/bin/sh vendor/bayareawebpro/laravel-simple-csv/split-csv.sh /Projects/laravel/storage/big-file.csv 5000
File Output:
/Projects/laravel/storage/big-file-chunk-1.csv (chunk of 5000)
/Projects/laravel/storage/big-file-chunk-2.csv (chunk of 5000)
/Projects/laravel/storage/big-file-chunk-3.csv (chunk of 5000)
etc...