table of contents
| Catmandu::Exporter::Table(3pm) | User Contributed Perl Documentation | Catmandu::Exporter::Table(3pm) |
NAME¶
Catmandu::Exporter::Table - ASCII/Markdown table exporter
SYNOPSIS¶
With catmandu command line client:
echo '{"one":"my","two":"table"} {"one":"is","two":"nice"}' | \
catmandu convert JSON --multiline 1 to Table
| one | two |
|-----|-------|
| my | table |
| is | nice |
catmandu convert CSV to Table --fields id,name --columns ID,Name < sample.csv
| ID | Name |
|----|------|
| 23 | foo |
| 42 | bar |
| 99 | doz |
In Perl scripts:
use Catmandu::Exporter::Table;
my $exp = Catmandu::Exporter::Table->new;
$exp->add({ title => "The Hobbit", author => "Tolkien" });
$exp->add({ title => "Where the Wild Things Are", author => "Sendak" });
$exp->add({ title => "One Thousand and One Nights" });
$exp->commit;
| author | title |
|---------|-----------------------------|
| Tolkien | The Hobbit |
| Sendak | Where the Wild Things Are |
| | One Thousand and One Nights |
DESCRIPTION¶
This Catmandu::Exporter exports data in tabular form, formatted in MultiMarkdown syntax.
The output can be used for simple display, for instance to preview Excel files on the command line. Use Pandoc <http://johnmacfarlane.net/pandoc/> too further convert to other table formats, e.g. "latex", "html5", "mediawiki":
catmandu convert XLS to Table < sheet.xls | pandoc -t html5
By default columns are sorted alphabetically by field name.
CONFIGURATION¶
Table output can be controlled with the options "fields", "columns", "widths", and "condense" as documented in Text::MarkdownTable.
- file
- fh
- encoding
- fix
- Standard options of <Catmandu:Exporter>
- condense
- Write table in condense format with unaligned columns.
- fields
- Field names as comma-separated list or array reference.
- columns
- Column names as comma-separated list or array reference. By default field names are used as column names.
- header
- Include header lines. Enabled by default.
- widths
- Column widths as comma-separated list or array references. Calculated from all rows by default. Long cell values can get truncated with this option.
- schema
- Supply fields and (optionally) columns in a JSON Table Schema
<http://dataprotocols.org/json-table-schema/> as JSON file or hash
reference having the following structure:
{ "fields: [ { "name": "field-name-1", "title": "column title 1 (optional)" }, { "name": "field-name-2", "title": "column title 2 (optional)" }, ... ] }
METHODS¶
See Catmandu::Exporter
SEE ALSO¶
This module is based on Text::MarkdownTable.
Similar Catmandu Exporters for tabular data include Catmandu::Exporter::CSV, Catmandu::Exporter::XLS, and Catmandu::Exporter::XLSX.
| 2023-02-11 | perl v5.36.0 |