Source code for bigframes.core.indexes.datetimes

# Copyright 2025 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

"""An index based on a single column with a datetime-like data type."""

from __future__ import annotations

from bigframes_vendored.pandas.core.indexes import (
    datetimes as vendored_pandas_datetime_index,
)

from bigframes.core import expression as ex
from bigframes.core.indexes.base import Index
from bigframes.operations import date_ops


[docs] class DatetimeIndex(Index, vendored_pandas_datetime_index.DatetimeIndex): __doc__ = vendored_pandas_datetime_index.DatetimeIndex.__doc__ # Must be above 5000 for pandas to delegate to bigframes for binops __pandas_priority__ = 12000 @property def year(self) -> Index: return self._apply_unary_expr(date_ops.year_op.as_expr(ex.free_var("arg"))) @property def month(self) -> Index: return self._apply_unary_expr(date_ops.month_op.as_expr(ex.free_var("arg"))) @property def day(self) -> Index: return self._apply_unary_expr(date_ops.day_op.as_expr(ex.free_var("arg"))) @property def dayofweek(self) -> Index: return self._apply_unary_expr(date_ops.dayofweek_op.as_expr(ex.free_var("arg"))) @property def day_of_week(self) -> Index: return self.dayofweek @property def weekday(self) -> Index: return self.dayofweek