Skip to content

DateTime

Built-in library for date & time

local DateTime = require("@lune/datetime")
-- Creates a DateTime for the current exact moment in time
local now = DateTime.now()
-- Formats the current moment in time as an RFC 3339 string
print(now:toRfc3339())
-- Formats the current moment in time as an RFC 2822 string
print(now:toRfc2822())
-- Formats the current moment in time, using the local
-- time, the French locale, and the specified time string
print(now:formatLocalTime("%A, %d %B %Y", "fr"))
-- Returns a specific moment in time as a DateTime instance
local someDayInTheFuture = DateTime.fromLocalTime({
year = 3033,
month = 8,
day = 26,
hour = 16,
minute = 56,
second = 28,
millisecond = 892,
})
-- Extracts the current local date & time as separate values (same values as above table)
print(now:toLocalTime())
-- Returns a DateTime instance from a given float, where the whole
-- denotes the seconds and the fraction denotes the milliseconds
-- Note that the fraction for millis here is completely optional
DateTime.fromUnixTimestamp(871978212313.321)
-- Extracts the current universal (UTC) date & time as separate values
print(now:toUniversalTime())

number

Number of seconds passed since the UNIX epoch.


number

Number of milliseconds passed since the UNIX epoch.


Returns a DateTime representing the current moment in time.

  • DateTime The new DateTime object

Creates a new DateTime from the given UNIX timestamp.

This timestamp may contain both a whole and fractional part - where the fractional part denotes milliseconds / nanoseconds.

Example usage of fractions:

  • DateTime.fromUnixTimestamp(123456789.001) - one millisecond
  • DateTime.fromUnixTimestamp(123456789.000000001) - one nanosecond

Note that the fractional part has limited precision down to exactly one nanosecond, any fraction that is more precise will get truncated.

  • unixTimestamp number Seconds passed since the UNIX epoch
  • DateTime The new DateTime object

Creates a new DateTime from the given date & time values table, in universal (UTC) time.

The given table must contain the following values:

KeyTypeRange
yearnumber1400 -> 9999
monthnumber1 -> 12
daynumber1 -> 31
hournumber0 -> 23
minutenumber0 -> 59
secondnumber0 -> 60

An additional millisecond value may also be included, and should be within the range 0 -> 999, but is optional.

Any non-integer values in the given table will be rounded down.

This constructor is fallible and may throw an error in the following situations:

  • Date units (year, month, day) were given that produce an invalid date. For example, January 32nd or February 29th on a non-leap year.
  • values DateTimeValueArguments Table containing date & time values
  • DateTime The new DateTime object

Creates a new DateTime from the given date & time values table, in local time.

The given table must contain the following values:

KeyTypeRange
yearnumber1400 -> 9999
monthnumber1 -> 12
daynumber1 -> 31
hournumber0 -> 23
minutenumber0 -> 59
secondnumber0 -> 60

An additional millisecond value may also be included, and should be within the range 0 -> 999, but is optional.

Any non-integer values in the given table will be rounded down.

This constructor is fallible and may throw an error in the following situations:

  • Date units (year, month, day) were given that produce an invalid date. For example, January 32nd or February 29th on a non-leap year.
  • values DateTimeValueArguments Table containing date & time values
  • DateTime The new DateTime object

DEPRECATED: Use DateTime.fromRfc3339 instead.

Creates a new DateTime from an ISO 8601 date-time string.

This constructor is fallible and may throw an error if the given string does not strictly follow the ISO 8601 date-time string format.

Some examples of valid ISO 8601 date-time strings are:

  • 2020-02-22T18:12:08Z
  • 2000-01-31T12:34:56+05:00
  • 1970-01-01T00:00:00.055Z
  • isoDate string An ISO 8601 formatted string
  • DateTime The new DateTime object

Creates a new DateTime from an RFC 3339 date-time string.

This constructor is fallible and may throw an error if the given string does not strictly follow the RFC 3339 date-time string format.

Some examples of valid RFC 3339 date-time strings are:

  • 2020-02-22T18:12:08Z
  • 2000-01-31T12:34:56+05:00
  • 1970-01-01T00:00:00.055Z
  • rfc3339Date string An RFC 3339 formatted string
  • DateTime The new DateTime object

Creates a new DateTime from an RFC 2822 date-time string.

This constructor is fallible and may throw an error if the given string does not strictly follow the RFC 2822 date-time string format.

Some examples of valid RFC 2822 date-time strings are:

  • Fri, 21 Nov 1997 09:55:06 -0600
  • Tue, 1 Jul 2003 10:52:37 +0200
  • Mon, 23 Dec 2024 01:58:48 GMT
  • rfc2822Date string An RFC 2822 formatted string
  • DateTime The new DateTime object

Formats this DateTime using the given formatString and locale, as local time.

The given formatString is parsed using a strftime/strptime-inspired date and time formatting syntax, allowing tokens such as the following:

TokenExampleDescription
%Y1998Year number
%m04Month number
%d29Day number
%AMondayWeekday name
%M59Minute number
%S10Second number

For a full reference of all available tokens, see the chrono documentation.

If not provided, formatString and locale will default to "%Y-%m-%d %H:%M:%S" and "en" (english) respectively.

  • self DateTime

  • formatString string? A string containing formatting tokens

  • locale Locale? The locale the time should be formatted in

  • string The formatting string

Formats this DateTime using the given formatString and locale, as UTC (universal) time.

The given formatString is parsed using a strftime/strptime-inspired date and time formatting syntax, allowing tokens such as the following:

TokenExampleDescription
%Y1998Year number
%m04Month number
%d29Day number
%AMondayWeekday name
%M59Minute number
%S10Second number

For a full reference of all available tokens, see the chrono documentation.

If not provided, formatString and locale will default to "%Y-%m-%d %H:%M:%S" and "en" (english) respectively.

  • self DateTime

  • formatString string? A string containing formatting tokens

  • locale Locale? The locale the time should be formatted in

  • string The formatting string

DEPRECATED: Use DateTime.toRfc3339 instead.

Formats this DateTime as an ISO 8601 date-time string.

Some examples of ISO 8601 date-time strings are:

  • 2020-02-22T18:12:08Z
  • 2000-01-31T12:34:56+05:00
  • 1970-01-01T00:00:00.055Z
  • self DateTime
  • string The ISO 8601 formatted string

Formats this DateTime as an RFC 2822 date-time string.

Some examples of RFC 2822 date-time strings are:

  • Fri, 21 Nov 1997 09:55:06 -0600
  • Tue, 1 Jul 2003 10:52:37 +0200
  • Mon, 23 Dec 2024 01:58:48 GMT
  • self DateTime
  • string The RFC 2822 formatted string

Formats this DateTime as an RFC 3339 date-time string.

Some examples of RFC 3339 date-time strings are:

  • 2020-02-22T18:12:08Z
  • 2000-01-31T12:34:56+05:00
  • 1970-01-01T00:00:00.055Z
  • self DateTime
  • string The RFC 3339 formatted string

Extracts separated local date & time values from this DateTime.

The returned table contains the following values:

KeyTypeRange
yearnumber1400 -> 9999
monthnumber1 -> 12
daynumber1 -> 31
hournumber0 -> 23
minutenumber0 -> 59
secondnumber0 -> 60
millisecondnumber0 -> 999
  • self DateTime
  • DateTimeValueReturns A table of DateTime values

Extracts separated UTC (universal) date & time values from this DateTime.

The returned table contains the following values:

KeyTypeRange
yearnumber1400 -> 9999
monthnumber1 -> 12
daynumber1 -> 31
hournumber0 -> 23
minutenumber0 -> 59
secondnumber0 -> 60
millisecondnumber0 -> 999
  • self DateTime
  • DateTimeValueReturns A table of DateTime values

Enum type representing supported DateTime locales.

Currently supported locales are:

  • en - English
  • de - German
  • es - Spanish
  • fr - French
  • it - Italian
  • ja - Japanese
  • pl - Polish
  • pt-br - Brazilian Portuguese
  • pt - Portuguese
  • tr - Turkish

Individual date & time values, representing the primitives that make up a DateTime.

This is a dictionary that will contain the following values:

  • year - Year(s), in the range 1400 -> 9999
  • month - Month(s), in the range 1 -> 12
  • day - Day(s), in the range 1 -> 31
  • hour - Hour(s), in the range 0 -> 23
  • minute - Minute(s), in the range 0 -> 59
  • second - Second(s), in the range 0 -> 60, where 60 is a leap second

An additional millisecond value may also be included, and should be within the range 0 -> 999, but is optional.

However, any method returning this type should be guaranteed to include milliseconds - see individual methods to verify.


Alias for DateTimeValues with an optional millisecond value.

Refer to the DateTimeValues documentation for additional information.


Alias for DateTimeValues with a mandatory millisecond value.

Refer to the DateTimeValues documentation for additional information.