11 releases (6 stable)

1.3.1 Oct 17, 2024
1.3.0 Oct 1, 2024
1.2.0 Jul 23, 2024
1.0.0 May 16, 2024
0.1.3 Apr 16, 2024

#119 in Date and time

Download history 66/week @ 2024-09-22 235/week @ 2024-09-29 157/week @ 2024-10-06 285/week @ 2024-10-13 37/week @ 2024-10-20 20/week @ 2024-10-27 29/week @ 2024-11-03 24/week @ 2024-11-10 17/week @ 2024-11-17 29/week @ 2024-11-24 44/week @ 2024-12-01 55/week @ 2024-12-08 140/week @ 2024-12-15 77/week @ 2024-12-22 33/week @ 2024-12-29 29/week @ 2025-01-05

279 downloads per month

MIT license

39KB
928 lines

Date & Time

ci codecov release docs

The datetime crate provides a simple, easy-to-use DateTime struct (and corresponding macro). DateTime provides storage for a date and time, and optionally a time zone (if the tz feature is enabled).

The underlying storage is a Unix timestamp, so DateTime objects are comparable (even when in different time zones). Additonally, if you don't need the concept of time zones (e.g. because you can assume one), you can leave the tz feature off and not take the baggage.

A DateTime with no time zone specified behaves identically to UTC.

Examples

Making a DateTime:

use datetime::DateTime;

let dt = DateTime::ymd(2012, 4, 21).hms(11, 0, 0).build();

You can also use the datetime! macro to get a syntax resembling a date literal:

use datetime::datetime;

let dt = datetime! { 2012-04-21 11:00:00 };

Features

datetime-rs ships with the following features:

  • diesel-pg: Enables interop with PostgreSQL TIMESTAMP columns using Diesel.
  • serde: Enables serialization and desearialization with serde. (Enabled by default.)
  • tz: Enables support for time-zone-aware date construction.

Dependencies

~0.2–1.4MB
~27K SLoC