The RdnCsv Laminas module makes it really easy to export and import CSV files.
- 
Use composerto require theradnan/rdn-csvpackage:$ composer require radnan/rdn-csv:3.*
- 
Activate the module by including it in your application.config.phpfile:<?php return array( 'modules' => array( 'RdnCsv', // ... ), ); 
The module comes with two plugins - CsvExport() and CsvImport().
Export data into a downloadable CSV file using this plugin.
// inside a controller action
$header = array(
	'Year',
	'Make',
	'Model',
	'Description',
	'Price',
);
$records = array(
	array(
		'1997',
		'Ford',
		'E350',
		'ac, abs, moon',
		'3000.00',
	),
);
return $this->CsvExport('foo.csv', $header, $records);The plugin will return a response object which you can then return from your controller action.
Read more documentation on CsvExport()
Import data from a CSV file using this plugin.
// inside a controller action
$csv = $this->CsvImport('/path/to/foo.csv');
foreach ($csv as $row)
{
	var_dump($row);
	// array(
	//     'Year' => '1997',
	//     'Make' => 'Ford',
	//     'Model' => 'E350',
	//     'Description' => 'ac, abs, moon',
	//     'Price' => '3000.00',
	// )
}The plugin returns an iterator that can be used to loop over all the rows in the CSV file.