Provided by: libcatmandu-perl_1.2020-1_all
NAME
Catmandu - a data toolkit
SYNOPSIS
# From the command line # Convert data from one format to another $ catmandu convert JSON to CSV < data.json $ catmandu convert CSV to YAML < data.csv $ catmandu convert MARC to YAML < data.mrc # Fix data, add, delete, change fields $ catmandu convert JSON --fix 'move_field(title,my_title)' < data.json $ catmandu convert JSON --fix all_my_fixes.txt < data.json # Use a moustache preprocessor on the fix script $ catmandu convert JSON --fix all_my_fixes.txt --var opt1=foo --var opt2=bar < data.json # run a fix script $ catmandu run myfixes.fix # or, create an executable fix script $ cat myfixes.fix #!/usr/local/bin/catmandu run do importer(OAI,url:"http://biblio.ugent.be/oai") retain(_id) end $ chmod 755 myfixes.fix $ ./myfixes.fix
DESCRIPTION
Catmandu provides a command line tools for the conversion of various data formats including: JSON, YAML, RDF, CSV, TSV, XML and even Excel. Using extension modules, specialized conversions for metadata formats using in libraries, archives and museums is also supports. We provide support for MARC, MAB, MODS, OAI-PMH, PICA, PNX, RIS, LIDO, SRU and Z39.50. Specialized conversions require a mapping language. This is implemented in Catmandu using the `Fix` language. For a short introduction read Catmandu::Introduction. Online tutorials can be found at the end of this document.
INSTALL
From Source # Clone the directory git clone https://github.com/LibreCat/Catmandu # Build cd Catmandu cpanm -n -q --installdeps --skip-satisfied . perl Build.PL && ./Build && ./Build install Using Docker docker build -t librecat/catmandu . # Run catmandu with access to you local files at <YourDrive> docker run -v <YourDrive>:/home/catmandu/Home -it librecat/catmandu # E.g. docker run -v C:\Users\alice:/home/catmandu/Home -it librecat/catmandu
INSTALL EXTENSIONS
cpanm install <PackageName> # E.g. cpanm install Catmandu::MARC
POPULAR EXTENSIONS
Catmandu::Breaker Catmandu::Identifier Catmandu::MARC Catmandu::OAI Catmandu::PICA Catmandu::RDF Catmandu::SRU Catmandu::Stat Catmandu::Template Catmandu::Validator Catmandu::XLS Catmandu::XSD Catmandu::Z3950
SEE ALSO
introduction Catmandu::Introduction documentation <http://librecat.org/> blog <https://librecatproject.wordpress.com/> step-by-step introduction from basics <https://librecatproject.wordpress.com/2014/12/01/day-1-getting-catmandu/> command line client catmandu Perl API Catmandu::PerlAPI
AUTHOR
Nicolas Steenlant, "<nicolas.steenlant at ugent.be>"
CONTRIBUTORS
Patrick Hochstenbach, "patrick.hochstenbach at ugent.be" Nicolas Franck, "nicolas.franck at ugent.be" Johann Rolschewski, "jorol at cpan.org" Vitali Peil, "vitali.peil at uni-bielefeld.de" Jakob Voss, "nichtich at cpan.org" Magnus Enger, "magnus at enger.priv.no" Christian Pietsch, "christian.pietsch at uni-bielefeld.de" Dave Sherohman, "dave.sherohman at ub.lu.se" Snorri Briem, "snorri.briem at ub.lu.se" Pieter De Praetere, "pieter.de.praetere at helptux.be" Doug Bell Upsana, "me at upasana.me" Stefan Weil Tom Hukins
QUESTIONS, ISSUES & BUG REPORTS
For any questions on the use of our modules please join our mailing list at: librecat-dev@lists.uni-bielefeld.de or send in your bug reports or feature requests to our issue tracker at: https://github.com/LibreCat/Catmandu/issues
LICENSE AND COPYRIGHT
This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License. See <http://dev.perl.org/licenses/> for more information.