A Singer Tap for extracting data from CSV files built using the Meltano SDK.
CSV tap class.
Built with the Meltano SDK for Singer Taps and Targets.
sync
catalog
discover
Note: This tap currently does not support incremental state.
Setting | Required | Default | Description |
---|---|---|---|
files | False | None | An array of csv file stream settings. |
csv_files_definition | False | None | A path to the JSON file holding an array of file settings. |
add_metadata_columns | False | False | When True, add the metadata columns (_sdc_source_file , _sdc_source_file_mtime , _sdc_source_lineno ) to output. |
A full list of supported settings and capabilities is available by running: tap-csv --about
The config.json
contains an array called files
that consists of dictionary objects detailing each destination table to be passed to Singer. Each of those entries contains:
entity
: The entity name to be passed to singer (i.e. the table)path
: Local path to the file to be ingested. Note that this may be a directory, in which case all files in that directory and any of its subdirectories will be recursively processedkeys
: The names of the columns that constitute the unique keys for that entityencoding
: [Optional] The file encoding to use when reading the file (i.e. "latin1", "UTF-8"). Use this setting when you get aUnicodeDecodeError
error.
The following entries are passed through in an internal CSV dialect that then is used to configure the CSV reader:
delimiter
: A one-character string used to separate fields. It defaults to ','.doublequote
: Controls how instances of quotechar appearing inside a field should themselves be quoted. When True, the character is doubled. When False, the escapechar is used as a prefix to the quotechar. It defaults to True.escapechar
: A one-character string used by the reader, where the escapechar removes any special meaning from the following character. It defaults to None, which disables escaping.quotechar
: A one-character string used to quote fields containing special characters, such as the delimiter or quotechar, or which contain new-line characters. It defaults to '"'.skipinitialspace
: When True, spaces immediately following the delimiter are ignored. The default is False.strict
: When True, raise exception Error on bad CSV input. The default is False.
Example:
{
"files": [
{ "entity" : "leads",
"path" : "/path/to/leads.csv",
"keys" : ["Id"],
"delimiter": ";"
},
{ "entity" : "opportunities",
"path" : "/path/to/opportunities.csv",
"keys" : ["Id"],
"encoding" : "latin1",
"skipinitialspace": true
}
]
}
Optionally, the files definition can be provided by an external json file:
config.json
{
"csv_files_definition": "files_def.json"
}
files_def.json
[
{ "entity" : "leads",
"path" : "/path/to/leads.csv",
"keys" : ["Id"]
},
{ "entity" : "opportunities",
"path" : "/path/to/opportunities.csv",
"keys" : ["Id"]
}
]
pipx install git+https://github.com/MeltanoLabs/tap-csv.git
You can easily run tap-csv
by itself or in a pipeline using Meltano.
tap-csv --version
tap-csv --help
tap-csv --config CONFIG --discover > ./catalog.json
pipx install poetry
poetry install
Create tests within the tap_csv/tests
subfolder and
then run:
poetry run tox
poetry run tox -e pytest
poetry run tox -e format
poetry run tox -e lint
You can also test the tap-csv
CLI interface directly using poetry run
:
poetry run tap-csv --help
Testing with Meltano
Note: This tap will work in any Singer environment and does not require Meltano. Examples here are for convenience and to streamline end-to-end orchestration scenarios.
Your project comes with a custom meltano.yml
project file already created. Open the meltano.yml
and follow any "TODO" items listed in
the file.
Next, install Meltano (if you haven't already) and any needed plugins:
# Install meltano
pipx install meltano
# Initialize meltano within this directory
cd tap-csv
meltano install
Now you can test and orchestrate using Meltano:
# Test invocation:
meltano invoke tap-csv --version
# OR run a test `elt` pipeline:
meltano elt tap-csv target-jsonl
See the dev guide for more instructions on how to use the SDK to develop your own taps and targets.