cli-table

Continuous Integration Crates.io Documentation License

Rust crate for printing tables on command line.

Usage

Add cli-table in your Cargo.toms's dependencies section

toml [dependencies] cli-table = "0.4"

Simple usage

```rust use clitable::{format::Justify, printstdout, Cell, Style, Table};

let table = vec![ vec!["Tom".cell(), 10.cell().justify(Justify::Right)], vec!["Jerry".cell(), 15.cell().justify(Justify::Right)], vec!["Scooby Doo".cell(), 20.cell().justify(Justify::Right)], ] .table() .title(vec![ "Name".cell().bold(true), "Age (in years)".cell().bold(true), ]) .bold(true);

assert!(printstdout(table).isok()); ```

Below is the output of the table we created just now:

markdown +------------+----------------+ | Name | Age (in years) | <-- This row and all the borders/separators +------------+----------------+ will appear in bold | Tom | 10 | +------------+----------------+ | Jerry | 15 | +------------+----------------+ | Scooby Doo | 25 | +------------+----------------+

Derive macro

#[derive(Table)] can also be used to print a Vec or slice of structs as table.

```rust use clitable::{format::Justify, printstdout, Table, WithTitle};

[derive(Table)]

struct User { #[table(title = "ID", justify = "Justify::Right")] id: u64, #[table(title = "First Name")] firstname: &'static str, #[table(title = "Last Name")] lastname: &'static str, }

let users = vec![ User { id: 1, firstname: "Scooby", lastname: "Doo", }, User { id: 2, firstname: "John", lastname: "Cena", }, ];

assert!(printstdout(users.withtitle()).is_ok()); ```

Below is the output of the table we created using derive macro:

markdown +----+------------+-----------+ | ID | First Name | Last Name | <-- This row will appear in bold +----+------------+-----------+ | 1 | Scooby | Doo | +----+------------+-----------+ | 2 | John | Cena | +----+------------+-----------+

Field attributes

For more information on configurations available on derive macro, go to cli-table/examples/struct.rs.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.