keboola / csvmap
Flatten an object into a CSV file(s)
Installs: 4 212
Dependents: 2
Suggesters: 0
Security: 0
Stars: 3
Watchers: 19
Forks: 1
Open Issues: 1
Requires
- php: ^8.1
- ext-json: *
- keboola/csv: ^4.0
- keboola/php-csvtable: ^2.2
- keboola/php-utils: ^4.1
Requires (Dev)
- keboola/coding-standard: ^15.0
- php-parallel-lint/php-parallel-lint: ^1.3
- phpstan/phpstan: ^1.4
- phpunit/phpunit: >=7.5
- dev-master
- 2.3.0
- 2.2.0
- 2.1.0
- 2.0.0
- 1.1.0
- 1.0.0
- 0.6.0
- 0.5.0
- 0.4.0
- 0.3.0
- 0.2.6
- 0.2.5
- 0.2.4
- 0.2.3
- 0.2.2
- 0.2.1
- 0.2.0
- 0.1.3
- 0.1.2
- 0.1.1
- 0.1.0
- 0.0.8
- 0.0.7
- 0.0.6
- 0.0.5
- 0.0.4
- 0.0.3
- 0.0.2
- 0.0.1
- dev-update-CF-3202-fix-dates-before-1970
- dev-michaljurecko-patch-1
- dev-adamvyborny-CM-573-update-keboola/csv
- dev-adamvyborny-upgrade-keboola-csv
- dev-adamvyborny-upgrade-php
- dev-webrouse-COM-469-enhancements
- dev-webrouse-COM-487-update-csvtable
This package is auto-updated.
Last update: 2024-12-22 11:16:47 UTC
README
Installation
composer require keboola/csvmap
Usage
For example, map key key.nested
of each $data
array item, to CSV column mappedKey
.
$data = [
[
'id => '123',
'key' => [
'nested' => 'value1'
]
]
];
$mapping = [
'id' => [
'type' => 'column',
'mapping' => [
'destination' => 'id',
'primaryKey' => true,
]
],
'key.nested' => 'mappedKey'
];
$rootType = 'rootName';
$userData = [];
$parser = new Mapper($mapping, $writeHeader, $rootType);
$parser->parse($data, $userData);
$files = $parser->getCsvFiles();
$tempFilePath = $files['rootName']->getPathName();
Mapping
- The mapping is an array.
- The
key
corresponds to the one root/nested key in the source data. Default delimiter is.
, eg.key
,key.nested
. - The
value
is the mapping configuration for the given key. It isstring
(shorthand notation) orarray
.- There are 3 types of the mapping, defined by the
type
key: type
(optional),column
by default.column
will store the value from its key into a CSV columnuser
will look into an array in the second argument of the parse function and fill a CSV column with its valuetable
will create a "child" CSV and link through a primary key or a hash, if no primary key is defined
- There are 3 types of the mapping, defined by the
Column mapping
mapping
: Required, must containdestination
:destination
: Target column in the output CSV fileprimaryKey
: Optional, boolean. If set to true, the column will be included in the primary key
forceType
: Optional, if a value is not scalar, it'll be JSON encoded
Shorthand notation
- If the
value
is thestring
, then it is a shorthand notation for thecolumn
mapping. - The string value corresponds to
mapping.destination
.
Example shorthand notation:
[
'key.nested' => 'mappedKey'
]
... is equal to
[
'key.nested' => [
'type' => 'column',
'mapping' => [
'destination' => 'mappedKey'
]
]
]
Examples
Four different column
mappings.
[
'id' => [
'type' => 'column',
'mapping' => [
'destination' => 'id',
'primaryKey' => true,
]
],
'name' => 'name',
'info.url' => 'url,
'info.tags' => [
'type' => 'column',
'forceType' => true,
'mapping' => [
'destination' => 'tags'
]
]
]
User mapping
Same as column
, except the key of the object is not searched for in the parsed data, but in an array passed to the parser to inject user data
Table mapping
destination
: Required, a target CSV file nametableMapping
: Required, mapping of all child table's columns- Sub-mapping has the same structure as the root
$mapping
.
- Sub-mapping has the same structure as the root
parentKey
: Optional, can be used to set the parent/child link as a primary key in the child or override the link's column name in the childprimaryKey
: boolean, same as incolumn
destination
: Name of the link column (if not used, name of the parent table ._pk
is used by default)disable
: boolean, if set to non-false value, the parent key in the child table, as well as the column in the parent will not be saved
Note:
If the destination
is the same as the current parsed 'type' (destination of the parent),
parentKey.disable
must be true to preserve consistency of structure of the child and parent.
Map scalar items to a separated CSV
- Table mapping is useful when you need to map array of the objects to separate CSV tables.
- But sometimes you need to map an array of the scalar (not object) values, for example a list of tags.
- In this case, you can use an empty key in
tableMapping
to map a scalar value.
For example, we have this data:
[
['id' => 1, 'name' => 'dog', 'tags' => ['useful', 'pet', 'animal']],
['id' => 2, 'name' => 'mouse', 'tags' => ['harmful', 'animal']]
]
Example mapping:
[
'id' => [
'type' => 'column',
'mapping' => [
'destination' => 'id',
'primaryKey' => true,
]
],
'name' => 'name',
'tags' => [
'type' => 'table',
'destination' => 'tags',
'tableMapping' => [
'' => 'tagName' // empty key used to map scalar value
]
]
]
Results:
root.csv
:
"id","name"
"1","dog"
"2","mouse"
tags.csv
:
"tagName","root_pk"
"useful","1"
"pet","1"
"animal","1"
"harmful","2"
"animal","2"
Examples
Mixed column
and table
mappings.
[
'id' => [
'type' => 'column',
'mapping' => [
'destination' => 'id',
'primaryKey' => true,
]
],
'name' => "name,
'addresses' => [
'type' => 'table',
'destination' => 'addresses',
'tableMapping' => [
'number' => 'number',
'street' => [
'type' => 'table',
'destination' => 'streets',
'tableMapping' => [
'name' => 'name'
]
]
]
]
]
License
MIT licensed, see LICENSE file.