atk14 / csv-reader
Reads CSV data from a file or a string, detects automatically CSV format parameters
Installs: 21 328
Dependents: 6
Suggesters: 0
Security: 0
Stars: 0
Watchers: 4
Forks: 0
Open Issues: 0
Requires
- php: >=5.6.0
Requires (Dev)
- atk14/tester: *
This package is auto-updated.
Last update: 2024-12-30 19:01:28 UTC
README
Reads CSV data from a file or a string. Detects automatically CSV format parameters.
Basic usage
$csv_data = '
k1;k2;k3
v1;v2;v3
x1;x2;x3
y1;y2
z1
';
$csv_data = trim($csv_data);
$reader = CsvReader::FromData($csv_data);
// or
$reader = CsvReader::FromFile("path/to/file.csv");
$reader->getRowCount(); // 5
$reader->getColumnCount(); // 3
$rows = $reader->getRows();
// [
// ["k1","k2","k3"],
// ["v1","v2","v3"],
// ["x1","x2","x3"],
// ["y1","y2",""],
// ["z1","",""],
// ]
$rows = $reader->getRows(["offset" => 2]);
// [
// ["x1","x2","x3"],
// ["y1","y2",""],
// ["z1","",""],
// ]
$row = $reader->getRow(0);
// ["k1","k2","k3"]
$row = $reader->getRow(1);
// ["v1","v2","v3"]
$col = $reader->getColumn(0);
// ["k1","v1","x1","y1","z1"],
$col = $reader->getColumn(0,["offset" => 1]);
// ["v1","x1","y1","z1"],
$col = $reader->getColumn(2);
// ["k3","v3","x3","",""],
$col = $reader->getColumn(3);
// []
$rows = $reader->getAssociativeRows();
// [
// ["k1" => "v1", "k1" => "v2", "k3" => "v3"],
// ["k1" => "x1", "k1" => "x2", "k3" => "x3"],
// ["k1" => "y1", "k1" => "y2", "k3" => ""],
// ["k1" => "z1", "k1" => "", "k3" => ""],
// ]
$rows = $reader->getAssociativeRows(["header_line" => 1]); // counting from 0, so this is the 2nd line
// [
// ["v1" => "x1", "v1" => "x2", "v3" => "x3"],
// ["v1" => "y1", "v1" => "y2", "v3" => ""],
// ["v1" => "z1", "v1" => "", "v3" => ""],
// ]
$rows = $reader->getAssociativeRows(["keys" => ["f1","f2","f3"]]);
// [
// ["f1" => "k1", "k1" => "k2", "k3" => "k3"],
// ["f1" => "v1", "k1" => "v2", "k3" => "v3"],
// ["f1" => "x1", "k1" => "x2", "k3" => "x3"],
// ["f1" => "y1", "k1" => "y2", "k3" => ""],
// ["f1" => "z1", "k1" => "", "k3" => ""],
// ]
$rows = $reader->getAssociativeRows(["keys" => ["f1","f2","f3"], "offset" => 2]);
// [
// ["f1" => "x1", "k1" => "x2", "k3" => "x3"],
// ["f1" => "y1", "k1" => "y2", "k3" => ""],
// ["f1" => "z1", "k1" => "", "k3" => ""],
// ]
CSV format parameters auto-detection
The CsvReader detects format parameters automatically. If the auto-detection fails, format parameters can be specified explicitly.
$reader = CsvReader::FromData($csv_data,[
"delimiter" => ";",
"quote" => "'"
]);
// or
$reader = CsvReader::FromFile("path/to/file.csv",[
"delimiter" => ";",
"quote" => "'"
]);
Installation
composer require atk14/cvs-reader
Testing
composer update --dev
./vendor/bin/run_unit_tests test
License
CsvReader is free software distributed under the terms of the MIT license