#numbers #formatting #separators #commas

thousands

Adds digit separators to numbers, configurably

6 releases

Uses old Rust 2015

0.2.0 Oct 20, 2019
0.1.4 Oct 20, 2019
0.1.2 Sep 18, 2018

#26 in Value formatting

Download history 3146/week @ 2021-05-30 3369/week @ 2021-06-06 3207/week @ 2021-06-13 4232/week @ 2021-06-20 3616/week @ 2021-06-27 2914/week @ 2021-07-04 2923/week @ 2021-07-11 3146/week @ 2021-07-18 3259/week @ 2021-07-25 3380/week @ 2021-08-01 2956/week @ 2021-08-08 3529/week @ 2021-08-15 3202/week @ 2021-08-22 2293/week @ 2021-08-29 2994/week @ 2021-09-05 3845/week @ 2021-09-12

9,272 downloads per month
Used in 17 crates (8 directly)

MIT/Apache

22KB
376 lines

thousands

Build Status Crates.io License: MIT License: Apache 2.0

Provides a trait, Separable, for formatting numbers with separators between the digits. Typically this will be used to add commas or spaces every three digits from the right, but can be configured via a SeparatorPolicy.

Examples

The simplest way to use the library is with trait Separable’s method separate_with_commas method, which does what it sounds like:

use thousands::Separable;

 assert_eq!(   12345  .separate_with_commas(),  "12,345" );
 assert_eq!( (-12345) .separate_with_commas(), "-12,345" );
 assert_eq!(    9876.5.separate_with_commas(),   "9,876.5" );

There are also methods separate_with_spaces, separate_with_dots, and separate_with_underscores, in case you, your culture, or your file format prefer those separators.

However, it's also possible to pass a policy for different behavior:

use thousands::{Separable, SeparatorPolicy, digits};

let policy = SeparatorPolicy {
    separator: ',',
    groups:    &[3, 2],
    digits:    digits::ASCII_DECIMAL,
};

assert_eq!( 1234567890.separate_by_policy(policy), "1,23,45,67,890" );

Usage

It’s on crates.io, so you can add

[dependencies]
thousands = "0.2.0"

to your Cargo.toml.

This crate supports Rust version 1.22 and newer.

No runtime deps