2 releases

0.1.1 Jul 17, 2021
0.1.0 Jul 17, 2021

#255 in Date and time

Download history 2667/week @ 2023-12-18 918/week @ 2023-12-25 2255/week @ 2024-01-01 3374/week @ 2024-01-08 2320/week @ 2024-01-15 2835/week @ 2024-01-22 3340/week @ 2024-01-29 3415/week @ 2024-02-05 2644/week @ 2024-02-12 2992/week @ 2024-02-19 3326/week @ 2024-02-26 3522/week @ 2024-03-04 2914/week @ 2024-03-11 3075/week @ 2024-03-18 3030/week @ 2024-03-25 2659/week @ 2024-04-01

11,777 downloads per month
Used in 7 crates (2 directly)

MIT license

10KB
171 lines

parse-duration-rs

parse-duration-rs is a Rust port of Golang parse duration time.ParseDuration. It parses a duration string in a short form such as 100ms, 1h45m, and 3ns and return duration in nanoseconds.

The crate is called go-parse-duration and you can depend on it via cargo:

[dependencies]
go-parse-duration = "0.1"

Example

use go_parse_duration::{parse_duration, Error};

fn parse() -> Result<i64, Error> {
  let d = parse_duration("300us")?;
  Ok(d)
}

Usage with Chrono

Converting to Chrono duration can be done easily:

use chrono::Duration;
use go_parse_duration::{parse_duration, Error};

fn parse() -> Result<Duration, Error> {
  let d = parse_duration("1m")?;
  Ok(Duration::nanoseconds(d))
}

Author

Armin Primadi https://github.com/aprimadi (@ Sahamee)


lib.rs:

parse-duration-rs is a Rust port of Golang parse duration time.ParseDuration. It parses a duration string in a short form such as 100ms, 1h45m, and 3ns and return duration in nanoseconds.

The crate is called go-parse-duration and you can depend on it via cargo:

[dependencies]
go-parse-duration = "0.1"

Example

use go_parse_duration::{parse_duration, Error};

fn parse() -> Result<i64, Error> {
  let d = parse_duration("300us")?;
  Ok(d)
}

Usage with Chrono

Converting to Chrono duration can be done easily:

use chrono::Duration;
use go_parse_duration::{parse_duration, Error};

fn parse() -> Result<Duration, Error> {
  let d = parse_duration("1m")?;
  Ok(Duration::nanoseconds(d))
}

No runtime deps