diff --git a/pyiceberg/transforms.py b/pyiceberg/transforms.py index 22dcdfe88a..64ea1e5fbc 100644 --- a/pyiceberg/transforms.py +++ b/pyiceberg/transforms.py @@ -419,11 +419,17 @@ def transform(self, source: IcebergType) -> Callable[[Optional[S]], Optional[int if isinstance(source, DateType): def year_func(v: Any) -> int: + if isinstance(v, py_datetime.date): + v = datetime.date_to_days(v) + return datetime.days_to_years(v) elif isinstance(source, (TimestampType, TimestamptzType)): def year_func(v: Any) -> int: + if isinstance(v, py_datetime.datetime): + v = datetime.datetime_to_micros(v) + return datetime.micros_to_years(v) else: @@ -476,11 +482,17 @@ def transform(self, source: IcebergType) -> Callable[[Optional[S]], Optional[int if isinstance(source, DateType): def month_func(v: Any) -> int: + if isinstance(v, py_datetime.date): + v = datetime.date_to_days(v) + return datetime.days_to_months(v) elif isinstance(source, (TimestampType, TimestamptzType)): def month_func(v: Any) -> int: + if isinstance(v, py_datetime.datetime): + v = datetime.datetime_to_micros(v) + return datetime.micros_to_months(v) else: @@ -539,11 +551,17 @@ def transform(self, source: IcebergType) -> Callable[[Optional[S]], Optional[int if isinstance(source, DateType): def day_func(v: Any) -> int: + if isinstance(v, py_datetime.date): + v = datetime.date_to_days(v) + return v elif isinstance(source, (TimestampType, TimestamptzType)): def day_func(v: Any) -> int: + if isinstance(v, py_datetime.datetime): + v = datetime.datetime_to_micros(v) + return datetime.micros_to_days(v) else: @@ -604,6 +622,9 @@ def transform(self, source: IcebergType) -> Callable[[Optional[S]], Optional[int if isinstance(source, (TimestampType, TimestamptzType)): def hour_func(v: Any) -> int: + if isinstance(v, py_datetime.datetime): + v = datetime.datetime_to_micros(v) + return datetime.micros_to_hours(v) else: