NAME
Term::TablePrint - Print a table to the terminal.
VERSION
Version 0.003
SYNOPSIS
my $table = [ [ 'id', 'name' ],
[ 1, 'Ruth' ],
[ 2, 'John' ],
[ 3, 'Mark' ],
[ 4, 'Nena' ], ];
use Term::TablePrint qw( print_table );
print_table( $table );
# or OO style:
use Term::TablePrint;
my $pt = Term::TablePrint->new();
$pt->print_table( $table );
DESCRIPTION
print_table
prints a table to STDOUT
or to STDERR
if STDOUT
is redirected.
print_table
provides a cursor which highlights the row on which the cursor is located.
The user can scroll through the table with the cursor up/down keys - see USAGE.
If the table has more rows than the terminal, the table is divided up on as many pages as needed automatically.
If the cursor reaches the end of a page, the next page is shown automatically (until the last page is reached).
Also if the cursor reaches the topmost line, the previous page is shown automatically if it is not already the first one.
If the terminal is too narrow to print the table, the columns are adjusted to the available width automatically.
If the option "table_expand" is enabled and the highlighted row is selected, each column of that row is output in its one line preceded by the column name. This might be useful if the columns were cut due to the too low terminal width.
To get a proper output, print_table
uses the columns
method from Unicode::GCString to calculate the string length.
The array elements are processed with the following substitutions:
s/^\p{Space}+//;
s/\p{Space}+\z//;
s/\p{Space}+/ /g;
In addition, characters of the Unicode property "Other" are removed:
s/\p{C}//g;
The elements in a column are right-justified if one or more elements of that column do not look like a number, else they are left-justified.
METHODES
new
Returns an object. As an argument it can be passed a reference to a hash which holds the options as pairs of "option-name" and "option-value".
my $tp = Term::TablePrint->new( [ \%options ] );
print_table
Prints the table passed with the first argument.
$tp->print_table( $array_ref, [ \%options ] );
The first argument must be a reference to an array of arrays. The first array of the arrays holds the column names. The following arrays are the table rows where the elements of these arrays are the field values.
As a second and optional argument can be passed a reference to a hash which holds the options as pairs of "option-name" and "option-value".
SUBROUTINES
print_table
Prints the table passed with the first argument.
print_table( $array_ref, [ \%options ] );
The first argument must be a reference to an array of arrays. The first array of the arrays holds the column names. The following arrays are the table rows where the elements of these arrays are the field values.
As a second and optional argument can be passed a reference to a hash which holds the options as pairs of "option-name" and "option-value".
USAGE
Keys to move around
the
ArrowDown
key (or thej
key) to move down andArrowUp
key (or thek
key) to move up.the
PageUp
key (orCtrl-B
) to go back one page, thePageDown
key (orCtrl-F
) to go forward one page.the
Home
key (orCtrl-A
) to jump to the first row of the table, theEnd
key (orCtrl-E
) to jump to the last row of the table.the
Enter/Return
key to close the table or to print the highlighted row iftable_expand
is enabled.
With the option "table_expand" disabled:
- Pressing Enter/Return
jumps to the head of the table.
- Selecting the head of the table closes the table.
With the option "table_expand" enabled:
- If one selects a row twice in succession, the pointer jumps to the head of the table.
- Selecting the head of the table closes the table.
- If the width of the window is changed the user can rewrite the screen by choosing a row.
OPTIONS
Defaults may change in a future release.
tab_width
Set the number of spaces between columns.
Default: 2
min_col_width
Set the width the columns should have at least when printed. The columns which are below or equal the min_col_width
are only trimmed if it is still required to lower the row width despite all columns have trimmed to min_col_width
.
Default: 30
undef
Set the string that will be shown on the screen instead of an undefined field.
Default: "" (empty string)
max_rows
Set the maximum number of printed table rows.
To disable the automatic limit set max rows
to 0.
Default: 50_000
progress_bar
Set the progress bar threshold. If the number of fields (rows x columns) is higher than the threshold a progress bar is shown while preparing the data for the output.
Default: 20_000
table_expand
table_expand
set to 1 enables printing the chosen table row by pressing the ENTER
key.
Default: 1
mouse
Set the mouse
mode (see option "mouse" in "OPTIONS" in Term::Choose).
Default: 0
binary_filter
Print "BNRY" instead of arbitrary binary data.
If the data matches the repexp /[\x00-\x08\x0B-\x0C\x0E-\x1F]/
it is considered arbitrary binary data.
Printing arbitrary binary data could break the output.
Default: 0
REQUIREMENTS
Perl version
Requires Perl version 5.10.1 or greater.
Decoded strings
print_table
expects decoded strings.
encoding layer for STDOUT
For a correct output it is required to set an encoding layer for STDOUT matching the terminal's character set.
Monospaced font
It is required a terminal that uses a monospaced font which supports the printed characters.
SUPPORT
You can find documentation for this module with the perldoc command.
perldoc Term::TablePrint
AUTHOR
Matthäus Kiem <cuer2s@gmail.com>
CREDITS
Thanks to the Perl-Community.de and the people form stackoverflow for the help.
LICENSE AND COPYRIGHT
Copyright 2012-2014 Matthäus Kiem.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl 5.10.0. For details, see the full text of the licenses in the file LICENSE.