2 releases

Uses old Rust 2015

0.1.1 Oct 2, 2021
0.1.0 May 7, 2019

#368 in Text processing

Download history 394/week @ 2024-06-19 194/week @ 2024-06-26 155/week @ 2024-07-03 126/week @ 2024-07-10 232/week @ 2024-07-17 152/week @ 2024-07-24 70/week @ 2024-07-31 95/week @ 2024-08-07 105/week @ 2024-08-14 141/week @ 2024-08-21 418/week @ 2024-08-28 287/week @ 2024-09-04 222/week @ 2024-09-11 417/week @ 2024-09-18 218/week @ 2024-09-25 261/week @ 2024-10-02

1,171 downloads per month
Used in 9 crates (6 directly)

MIT/Apache

315KB
5.5K SLoC

float-pretty-print

Round and format f64 number for showing it to humans, with configurable minimum and maximum width. It automatically switches between exponential and usual forms as it sees fit.

It works by trying usual format!, possibly multiple times and inspecting the resulting string.

Only two formatting parameters are supported:

  • width is minimum width
  • precision is maximum width

### is printed if it can't output the number with given constraint.

Example:

  use float_pretty_print::PrettyPrintFloat;
  assert_eq!(format!("{}", PrettyPrintFloat(3.45)), "3.45");
  assert_eq!(format!("{}", PrettyPrintFloat(12.0)), "12.0");
  assert_eq!(format!("{}", PrettyPrintFloat(120000000.0)), "1.2e8");
  assert_eq!(format!("{:5.5}", PrettyPrintFloat(12345.0)), "12345");
  assert_eq!(format!("{:5.5}", PrettyPrintFloat(12.345)), "12.35");
  assert_eq!(format!("{:5.5}", PrettyPrintFloat(0.12345)), "0.123");
  assert_eq!(format!("{:5.5}", PrettyPrintFloat(1234500000.0)), "1.2e9");
  assert_eq!(format!("{:5.5}", PrettyPrintFloat(12345.0e-19)), "1e-15");
  assert_eq!(format!("{:5.5}", PrettyPrintFloat(12345.0e-100)), "1e-96");
  assert_eq!(format!("{:5.5}", PrettyPrintFloat(12345.0e-130)), "    0");
  assert_eq!(format!("{:5.5}", PrettyPrintFloat(12345.0e+130)), "1e134");
  assert_eq!(format!("{:4.4}", PrettyPrintFloat(12345.0e+130)), "####");
  assert_eq!(format!("{:6.6}", PrettyPrintFloat(12345.0e-130)), "1e-126");

Supports even Rust 1.23

No runtime deps