popphp / pop-csv
Pop CSV Component for Pop PHP Framework
Installs: 3 990
Dependents: 1
Suggesters: 0
Security: 0
Stars: 4
Watchers: 3
Forks: 0
Open Issues: 0
Requires
- php: >=8.2.0
Requires (Dev)
- phpunit/phpunit: ^11.0.0
README
Overview
pop-csv
provides a streamlined way to work with PHP data and the CSV format.
It is a component of the Pop PHP Framework.
Install
Install pop-csv
using Composer.
composer require popphp/pop-csv
Or, require it in your composer.json file
"require": {
"popphp/pop-csv" : "^4.1.1"
}
Quickstart
Create a CSV string
$phpData = [ [ 'first_name' => 'Bob', 'last_name' => 'Smith' ], [ 'first_name' => 'Jane', 'last_name' => 'Smith' ] ]; $data = new Pop\Csv\Csv($phpData); $csvString = $data->serialize();
The $csvString variable now contains:
first_name,last_name
Bob,Smith
Jane,Smith
Create data from a CSV string
You can either pass the data object a direct string of serialized data or a file containing a string of serialized data. It will detect which one it is and parse it accordingly.
$csv = new Pop\Csv\Csv($csvString); $phpData = $csv->unserialize();
Options
Where serializing or unserializing CSV data, there are a set of options available to tailor the process:
$options = [ 'exclude' => ['id'] // An array of fields to exclude from displaying 'delimiter' => ',' // Delimiter defaults to ',' - could be "\t" or something else 'enclosure' => '"' // Default string enclosure, i.e. "my data","other data" 'escape' => '"' // String character to escape in the data, i.e. "my ""data"" here" 'fields' => true // Include the field names in the first row 'newline' => true // Allow newlines in a data cell. Set to false to trim them 'limit' => 0 // Character limit of a data cell. 0 means no limit ];
Conversely, include
can be used to only include the fields in the include
array:
$options = [ 'include' => ['username', 'first_name', 'last_name'] // An array of fields to include from displaying
Pass the options array to serialize()
or unserialize()
methods:
$csvString = $csv->serialize($options); $csvData = $csv->unserialize($options);
Output CSV
Write to File
$phpData = [ [ 'first_name' => 'Bob', 'last_name' => 'Smith' ], [ 'first_name' => 'Jane', 'last_name' => 'Smith' ] ]; $data = new Pop\Csv\Csv($phpData); $data->writeToFile('/path/to/file.csv');
Output to HTTP
$phpData = [ [ 'first_name' => 'Bob', 'last_name' => 'Smith' ], [ 'first_name' => 'Jane', 'last_name' => 'Smith' ] ]; $data = new Pop\Csv\Csv($phpData); $data->outputToHttp('my-file.csv');
Force download of file
Pass a true
boolean as the second parameter, which forces attachment
for the Content-Disposition
header.
$data->outputToHttp('my-file.csv', true);
Additional HTTP headers
Additional HTTP headers can be passed to the third parameter:
$data->outputToHttp('my-file.csv', false, ['X-Header' => 'some-header-value']);
Append Data
In the case of working with large data sets, you can append CSV data to an existing file on disk. This prevents loading large amounts of data into memory that may exceed the PHP environment's limits.
us Pop\Csv\Csv; $phpData = [ [ 'first_name' => 'Bob', 'last_name' => 'Smith' ], [ 'first_name' => 'Jane', 'last_name' => 'Smith' ] ]; Csv::appendDataToFile('my-file.csv', $data);