1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
//! This example demonstrates using the [`Width`] [`TableOption`] to expand and
//! contract a [`Table`] display.
//!
//! * Note how table-wide size adjustments are applied proportionally to all columns.
//!
//! * Note how [fluent](https://en.wikipedia.org/wiki/Fluent_interface) functions
//! are available to make subtle customizations to [`Width`] primary features like
//! [`Width::truncate()`], [`Width::increase()`], and [`Width::wrap()`].
use tabled::{
settings::{measurement::Percent, object::Segment, Alignment, Modify, Style, Width},
Table,
};
fn main() {
let data = [
["Hello World!!!", "3.3.22.2"],
["Guten Morgen", "1.1.1.1"],
["Добры вечар", "127.0.0.1"],
["Bonjour le monde", ""],
["Ciao mondo", ""],
];
let mut table = Table::builder(data).build();
table.with(Style::markdown()).with(Alignment::left());
println!("Original table\n{table}\n");
table.with(Width::truncate(20).suffix("..."));
println!("Truncated table\n{table}\n");
table.with(Modify::new(Segment::all()).with(Width::wrap(5)));
println!("Wrapped table\n{table}\n");
table.with(Width::increase(Percent(200)));
println!("Widen table\n{table}");
}
|