# NAME Text::UnicodeTable::Simple - Create a formatted table using characters. # SYNOPSIS use Text::UnicodeTable::Simple; $t = Text::UnicodeTable::Simple->new(); $t->set_header(qw/Subject Score/); $t->add_row('English', '78'); $t->add_row('Mathematics', '91'); $t->add_row('Chemistry', '64'); $t->add_row('Physics', '95'); $t->add_row_line(); $t->add_row('Total', '328'); print "$t"; # Result: .-------------+-------. | Subject | Score | +-------------+-------+ | English | 78 | | Mathematics | 91 | | Chemistry | 64 | | Physics | 95 | +-------------+-------+ | Total | 328 | '-------------+-------' # DESCRIPTION Text::UnicodeTable::Simple creates character table. There are some modules for creating a text table at CPAN, [Text::ASCIITable](http://search.cpan.org/perldoc?Text::ASCIITable), [Text::SimpleTable](http://search.cpan.org/perldoc?Text::SimpleTable), [Text::Table](http://search.cpan.org/perldoc?Text::Table) etc. But those module deal with only ASCII, don't deal with full width characters. If you use them with full width characters, a table created may be bad-looking. Text::UnicodeTable::Simple resolves problem of full width characters. So you can use Japansese Hiragana, Katakana, Korean Hangeul, Chinese Kanji characters. See `eg/` directory for examples. # INTERFACE ## Methods ### new(%args) Creates and returns a new table instance with _%args_. _%args_ might be - header :ArrayRef Table header. If you set table header with constructor, you can omit `set_header` method. - border :Bool = True Table has no border if `border` is False. - ansi\_color :Bool = False Ignore ANSI color escape sequence ### set\_header() \[alias: addCols \] Set the headers for the table. (compare with <th> in HTML). You must call `set_header` firstly. If you call other methods without calling `set_header`, then you fail. Input strings should be __string__, not __octet stream__. ### add\_row(@list\_of\_columns | \\@list\_of\_columns) \[alias: addRow \] Add one row to the table. Input strings should be __string__, not __octet stream__. ### add\_rows(@list\_of\_columns) Add rows to the table. You can add row at one time. Each `@collists` element should be ArrayRef. ### add\_row\_line() \[alias: addRowLine \] Add a line after the current row. If 'border' parameter is false, add a new line. ### draw() Return the table as string. Text::UnicodeTable::Simple overload stringify operator, so you can omit `->draw()` method. # AUTHOR Syohei YOSHIDA <syohex@gmail.com> # COPYRIGHT Copyright 2011- Syohei YOSHIDA # SEE ALSO [Text::ASCIITable](http://search.cpan.org/perldoc?Text::ASCIITable) [Text::SimpleTable](http://search.cpan.org/perldoc?Text::SimpleTable) [Text::Table](http://search.cpan.org/perldoc?Text::Table) # LICENSE This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.