Catmandu(3pm) | User Contributed Perl Documentation | Catmandu(3pm) |
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.
2023-03-03 | perl v5.36.0 |