#table #print #terminal #format #pretty-table #macro-derive #pretty-print

no-std tabled

An easy to use library for pretty print tables of Rust structs and enums

33 unstable releases

0.17.0 Nov 22, 2024
0.15.0 Dec 20, 2023
0.14.0 Aug 4, 2023
0.13.0 Jul 24, 2023
0.1.0 Mar 23, 2020

#1 in Visualization

Download history 95460/week @ 2024-09-23 112005/week @ 2024-09-30 92298/week @ 2024-10-07 111593/week @ 2024-10-14 99029/week @ 2024-10-21 106949/week @ 2024-10-28 80932/week @ 2024-11-04 126515/week @ 2024-11-11 135699/week @ 2024-11-18 90376/week @ 2024-11-25 135214/week @ 2024-12-02 132065/week @ 2024-12-09 113478/week @ 2024-12-16 40442/week @ 2024-12-23 51209/week @ 2024-12-30 137237/week @ 2025-01-06

349,210 downloads per month
Used in 396 crates (298 directly)

MIT license

1MB
23K SLoC

github crates.io docs.rs build status coverage dependency status

tabled

An easy to use library for pretty printing tables of Rust structs and enums.

There are more examples and you can find in this README.

Usage

To print a list of structs or enums as a table your types should implement the the Tabled trait or derive it with a #[derive(Tabled)] macro. Most of the default types implement the trait out of the box.

Most of a table configuration can be found in tabled::settings module.

use tabled::{Table, Tabled};
use testing_table::assert_table;

#[derive(Tabled)]
struct Language<'a> {
    name: &'a str,
    designed_by: &'a str,
    invented_year: usize,
}

let languages = vec![
    Language { name: "C",    designed_by: "Dennis Ritchie", invented_year: 1972 },
    Language { name: "Go",   designed_by: "Rob Pike",       invented_year: 2009 },
    Language { name: "Rust", designed_by: "Graydon Hoare",  invented_year: 2010 },
    Language { name: "Hare", designed_by: "Drew DeVault",   invented_year: 2022 },
];

let table = Table::new(languages);

assert_table!(
    table,
    "+------+----------------+---------------+"
    "| name | designed_by    | invented_year |"
    "+------+----------------+---------------+"
    "| C    | Dennis Ritchie | 1972          |"
    "+------+----------------+---------------+"
    "| Go   | Rob Pike       | 2009          |"
    "+------+----------------+---------------+"
    "| Rust | Graydon Hoare  | 2010          |"
    "+------+----------------+---------------+"
    "| Hare | Drew DeVault   | 2022          |"
    "+------+----------------+---------------+"
);

The same example but we are building a table step by step.

use tabled::{builder::Builder, settings::Style};
use testing_table::assert_table;

let mut builder = Builder::new();
builder.push_record(["C", "Dennis Ritchie", "1972"]);
builder.push_record(["Go", "Rob Pike", "2009"]);
builder.push_record(["Rust", "Graydon Hoare", "2010"]);
builder.push_record(["Hare", "Drew DeVault", "2022"]);

let mut table = builder.build();
table.with(Style::ascii_rounded());

assert_table!(
    table,
    ".------------------------------."
    "| C    | Dennis Ritchie | 1972 |"
    "| Go   | Rob Pike       | 2009 |"
    "| Rust | Graydon Hoare  | 2010 |"
    "| Hare | Drew DeVault   | 2022 |"
    "'------------------------------'"
);

Dependencies

~1.5–2MB
~33K SLoC