hour()#

relationalai.std.dates
#hour(date: datetime|Producer, tz: str|Producer = "UTC") -> Expression

Extracts the hour component from a UTC datetime value. If tz is specified, then date is converted from UTC to the specified timezone before extracting the hour. tz is ignored if date is a Python datetime object. If any of the arguments are Producer objects, then hour() also acts as a filter and removes invalid values from the producer, including dates. Must be called in a rule or query context.

Parameters#

NameTypeDescription
dateProducer or Python datetime objectThe date or datetime value from which to extract the hour.
tzProducer or Python str objectOptional timezone string (e.g., "America/New_York"), offset string (e.g., "+0600"), or Python tzinfo object. Refer to the timezone database for a list of valid timezone identifiers. Ignored if date is a Python date or datetime object. (Default: "UTC").

Returns#

An Expression object.

Raises#

TypeError if the date parameter is not a Producer object or Python date or datetime object.

Example#

Use hour() to extract the hour component from UTC datetime values:

#import relationalai as rai
from relationalai.std import alias, dates


# =====
# SETUP
# =====

model = rai.Model("MyModel2")
Event = model.Type("Event")

with model.rule():
    Event.add(id=1).set(time=dates.datetime(2021, 1, 1, 1, 30))
    Event.add(id=2).set(time="invalid")


# =======
# EXAMPLE
# =======

with model.rule():
    event = Event()
    # hour() filters out any events with invalid time values, so the
    # following only sets the hour property for Event 1.
    event.set(hour=dates.hour(event.time))
    # Since Event 2 is filtered out above, the following only sets the
    # has_valid_time property for Event 1.
    event.set(has_valid_time=True)

with model.query() as select:
    event = Event()
    response = select(event.id, event.time, event.hour, event.has_valid_time)

print(response.results)
#    id                 time  hour has_valid_time
# 0   1  2021-01-01 01:30:00   1.0           True
# 1   2              invalid   NaN            NaN

If the tz parameter is specified, the datetime is converted from UTC to the specified timezone before extracting the hour:

#with model.query() as select:
    event = Event()
    hour1 = dates.hour(event.time, tz="America/New_York")
    hour2 = dates.hour(event.time, tz="+0600")
    response = select(event.id, event.time, alias(hour1, "hour1"), alias(hour2, "hour2"))

print(response.results)
#    id                time  hour1  hour2
# 0   1 2021-01-01 01:30:00     20      7

Note that hour() does not return 0 for date values. Instead, because hour() expects a datetime value, date values are filtered out:

#with model.query() as select:
    date = dates.date(2021, 1, 1)
    response = select(dates.hour(date))

print(response.results)
# Empty DataFrame
# Columns: []
# Index: []

See Also#