Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ENH: Improve general datetime functions #352

Merged
merged 15 commits into from
Oct 4, 2022
16 changes: 12 additions & 4 deletions pandas-stubs/_libs/tslibs/timedeltas.pyi
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ from typing import (
ClassVar,
Literal,
TypeVar,
Union,
overload,
)

Expand All @@ -17,10 +18,7 @@ from pandas._typing import npt

# This should be kept consistent with the keys in the dict timedelta_abbrevs
# in pandas/_libs/tslibs/timedeltas.pyx
UnitChoices: TypeAlias = Literal[
"Y",
"y",
"M",
TimeDeltaUnitChoices: TypeAlias = Literal[
"W",
"w",
"D",
Expand Down Expand Up @@ -60,6 +58,16 @@ UnitChoices: TypeAlias = Literal[
"nanosecond",
"n",
]

UnitChoices: TypeAlias = Union[
TimeDeltaUnitChoices,
Literal[
"Y",
"y",
"M",
],
]

_S = TypeVar("_S", bound=timedelta)

def ints_to_pytimedelta(
Expand Down
24 changes: 23 additions & 1 deletion pandas-stubs/_typing.pyi
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ from typing import (
import numpy as np
from numpy import typing as npt
from pandas.core.arrays import ExtensionArray
from pandas.core.frame import DataFrame
from pandas.core.generic import NDFrame
from pandas.core.groupby.grouper import Grouper
from pandas.core.indexes.base import Index
Expand Down Expand Up @@ -46,6 +47,27 @@ PandasScalar: TypeAlias = Union[

DatetimeLike: TypeAlias = Union[datetime.datetime, np.datetime64, Timestamp]

DatetimeDictArg: TypeAlias = Union[
Sequence[int], Sequence[float], list[str], tuple[Scalar, ...], AnyArrayLike
]
DictConvertible: TypeAlias = Union[FulldatetimeDict, DataFrame]

class YearMonthDayDict(TypedDict, total=True):
year: DatetimeDictArg
month: DatetimeDictArg
day: DatetimeDictArg

class FulldatetimeDict(YearMonthDayDict, total=False):
hour: DatetimeDictArg
hours: DatetimeDictArg
minute: DatetimeDictArg
minutes: DatetimeDictArg
second: DatetimeDictArg
seconds: DatetimeDictArg
ms: DatetimeDictArg
us: DatetimeDictArg
ns: DatetimeDictArg

# dtypes
NpDtype: TypeAlias = Union[
str, np.dtype[np.generic], type[Union[str, complex, bool, object]]
Expand Down Expand Up @@ -178,7 +200,7 @@ IndexingInt: TypeAlias = Union[
int, np.int_, np.integer, np.unsignedinteger, np.signedinteger, np.int8
]
TimestampConvertibleTypes: TypeAlias = Union[
Timestamp, datetime.datetime, np.datetime64, np.int64, float, str
Timestamp, datetime.datetime, datetime.date, np.datetime64, np.int64, float, str
]
TimedeltaConvertibleTypes: TypeAlias = Union[
Timedelta, datetime.timedelta, np.timedelta64, np.int64, float, str
Expand Down
30 changes: 24 additions & 6 deletions pandas-stubs/core/indexes/datetimes.pyi
Original file line number Diff line number Diff line change
@@ -1,8 +1,13 @@
from datetime import (
date,
timedelta,
tzinfo,
)
from typing import overload
from typing import (
Hashable,
Sequence,
overload,
)

import numpy as np
from pandas import (
Expand Down Expand Up @@ -90,20 +95,33 @@ def date_range(
freq: str | timedelta | Timedelta | BaseOffset = ...,
tz: str | tzinfo = ...,
normalize: bool = ...,
name: str | None = ...,
name: Hashable | None = ...,
inclusive: IntervalClosedType = ...,
**kwargs,
) -> DatetimeIndex: ...
@overload
def bdate_range(
start: str | DatetimeLike | None = ...,
end: str | DatetimeLike | None = ...,
periods: int | None = ...,
freq: str | timedelta | Timedelta | BaseOffset = ...,
tz: str | tzinfo = ...,
normalize: bool = ...,
name: str | None = ...,
name: Hashable | None = ...,
weekmask: str | None = ...,
holidays: None = ...,
inclusive: IntervalClosedType = ...,
) -> DatetimeIndex: ...
@overload
def bdate_range(
start: str | DatetimeLike | None = ...,
end: str | DatetimeLike | None = ...,
periods: int | None = ...,
*,
freq: str | timedelta | Timedelta | BaseOffset,
tz: str | tzinfo = ...,
normalize: bool = ...,
name: Hashable | None = ...,
weekmask: str | None = ...,
holidays: list | None = ...,
holidays: Sequence[str | DatetimeLike | date],
inclusive: IntervalClosedType = ...,
**kwargs,
) -> DatetimeIndex: ...
11 changes: 10 additions & 1 deletion pandas-stubs/core/indexes/period.pyi
Original file line number Diff line number Diff line change
@@ -1,9 +1,14 @@
from typing import Hashable

import numpy as np
import pandas as pd
from pandas.core.indexes.datetimelike import (
DatetimeIndexOpsMixin as DatetimeIndexOpsMixin,
)
from pandas.core.indexes.numeric import Int64Index

from pandas._libs.tslibs import BaseOffset

class PeriodIndex(DatetimeIndexOpsMixin, Int64Index):
def __new__(
cls,
Expand Down Expand Up @@ -46,5 +51,9 @@ class PeriodIndex(DatetimeIndexOpsMixin, Int64Index):
def memory_usage(self, deep: bool = ...): ...

def period_range(
start=..., end=..., periods=..., freq=..., name=...
start: str | pd.Period | None = ...,
end: str | pd.Period | None = ...,
periods: int | None = ...,
freq: str | BaseOffset | None = ...,
Dr-Irv marked this conversation as resolved.
Show resolved Hide resolved
name: Hashable | None = ...,
) -> PeriodIndex: ...
19 changes: 16 additions & 3 deletions pandas-stubs/core/indexes/timedeltas.pyi
Original file line number Diff line number Diff line change
@@ -1,5 +1,10 @@
from typing import overload
from typing import (
Hashable,
Literal,
overload,
)

from pandas import DateOffset
from pandas.core.indexes.accessors import TimedeltaIndexProperties
from pandas.core.indexes.datetimelike import DatetimeTimedeltaMixin
from pandas.core.indexes.datetimes import DatetimeIndex
Expand All @@ -9,7 +14,10 @@ from pandas._libs import (
Timedelta,
Timestamp,
)
from pandas._typing import num
from pandas._typing import (
TimedeltaConvertibleTypes,
num,
)

class TimedeltaIndex(DatetimeTimedeltaMixin, TimedeltaIndexProperties):
def __new__(
Expand Down Expand Up @@ -42,5 +50,10 @@ class TimedeltaIndex(DatetimeTimedeltaMixin, TimedeltaIndexProperties):
def to_series(self, index=..., name=...) -> TimedeltaSeries: ...

def timedelta_range(
start=..., end=..., periods=..., freq=..., name=..., closed=...
start: TimedeltaConvertibleTypes = ...,
end: TimedeltaConvertibleTypes = ...,
bashtage marked this conversation as resolved.
Show resolved Hide resolved
periods: int | None = ...,
freq: str | DateOffset | None = ...,
name: Hashable | None = ...,
closed: Literal["left", "right"] | None = ...,
) -> TimedeltaIndex: ...
55 changes: 22 additions & 33 deletions pandas-stubs/core/tools/datetimes.pyi
Original file line number Diff line number Diff line change
@@ -1,18 +1,21 @@
from datetime import datetime
from datetime import (
date,
datetime,
)
from typing import (
Literal,
TypedDict,
Sequence,
Union,
overload,
)

import numpy as np
import pandas as pd
from pandas import (
Index,
Timestamp,
)
from pandas.core.arrays import ExtensionArray
from pandas.core.frame import DataFrame
from pandas.core.indexes.datetimes import DatetimeIndex
from pandas.core.series import (
Series,
Expand All @@ -24,38 +27,18 @@ from pandas._libs.tslibs import NaTType
from pandas._typing import (
AnyArrayLike,
DateTimeErrorChoices,
DictConvertible,
IgnoreRaise,
TimestampConvertibleTypes,
npt,
)

ArrayConvertible: TypeAlias = Union[list, tuple, AnyArrayLike]
Scalar: TypeAlias = Union[float, str]
DatetimeScalar: TypeAlias = Union[Scalar, datetime, np.datetime64]
DatetimeScalar: TypeAlias = Union[Scalar, datetime, np.datetime64, date]

DatetimeScalarOrArrayConvertible: TypeAlias = Union[DatetimeScalar, ArrayConvertible]

DatetimeDictArg: TypeAlias = Union[list[Scalar], tuple[Scalar, ...], AnyArrayLike]

class YearMonthDayDict(TypedDict, total=True):
year: DatetimeDictArg
month: DatetimeDictArg
day: DatetimeDictArg

class FulldatetimeDict(YearMonthDayDict, total=False):
hour: DatetimeDictArg
hours: DatetimeDictArg
minute: DatetimeDictArg
minutes: DatetimeDictArg
second: DatetimeDictArg
seconds: DatetimeDictArg
ms: DatetimeDictArg
us: DatetimeDictArg
ns: DatetimeDictArg

DictConvertible: TypeAlias = Union[FulldatetimeDict, DataFrame]

def should_cache(
arg: ArrayConvertible, unique_share: float = ..., check_count: int | None = ...
) -> bool: ...
@overload
def to_datetime(
arg: DatetimeScalar,
Expand All @@ -67,7 +50,7 @@ def to_datetime(
exact: bool = ...,
unit: str | None = ...,
infer_datetime_format: bool = ...,
origin=...,
origin: Literal["julian", "unix"] | TimestampConvertibleTypes = ...,
cache: bool = ...,
) -> Timestamp: ...
@overload
Expand All @@ -81,7 +64,7 @@ def to_datetime(
exact: bool = ...,
unit: str | None = ...,
infer_datetime_format: bool = ...,
origin=...,
origin: Literal["julian", "unix"] | TimestampConvertibleTypes = ...,
cache: bool = ...,
) -> Timestamp | NaTType: ...
@overload
Expand All @@ -95,12 +78,19 @@ def to_datetime(
exact: bool = ...,
unit: str | None = ...,
infer_datetime_format: bool = ...,
origin=...,
origin: Literal["julian", "unix"] | TimestampConvertibleTypes = ...,
cache: bool = ...,
) -> TimestampSeries: ...
@overload
def to_datetime(
arg: list | tuple | np.ndarray | Index | ExtensionArray,
arg: Sequence[int | float | datetime]
| list[str]
| tuple[int | float | str | datetime, ...]
| npt.NDArray[np.datetime64]
| npt.NDArray[np.str_]
| npt.NDArray[np.int_]
| Index
| ExtensionArray,
errors: DateTimeErrorChoices = ...,
dayfirst: bool = ...,
yearfirst: bool = ...,
Expand All @@ -109,7 +99,6 @@ def to_datetime(
exact: bool = ...,
unit: str | None = ...,
infer_datetime_format: bool = ...,
origin=...,
origin: Literal["julian", "unix"] | TimestampConvertibleTypes = ...,
cache: bool = ...,
) -> DatetimeIndex: ...
def to_time(arg, format=..., infer_time_format: bool = ..., errors: str = ...): ...
24 changes: 15 additions & 9 deletions pandas-stubs/core/tools/timedeltas.pyi
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
# def to_timedelta(arg, unit: str = ..., errors: str = ...): ...
from datetime import timedelta
from typing import overload
from typing import (
Sequence,
overload,
)

import pandas as pd
from pandas import Index
from pandas.core.indexes.timedeltas import TimedeltaIndex
from pandas.core.series import (
Expand All @@ -10,29 +13,32 @@ from pandas.core.series import (
)

from pandas._libs.tslibs import Timedelta
from pandas._libs.tslibs.timedeltas import UnitChoices
from pandas._libs.tslibs.timedeltas import TimeDeltaUnitChoices
from pandas._typing import (
ArrayLike,
DateTimeErrorChoices,
)

# Copied from pandas/_libs/tslibs/timedeltas.pyx

@overload
def to_timedelta(
arg: str | float | timedelta,
unit: UnitChoices | None = ...,
unit: TimeDeltaUnitChoices | None = ...,
errors: DateTimeErrorChoices = ...,
) -> Timedelta: ...
@overload
def to_timedelta(
arg: Series,
unit: UnitChoices | None = ...,
unit: TimeDeltaUnitChoices | None = ...,
errors: DateTimeErrorChoices = ...,
) -> TimedeltaSeries: ...
@overload
def to_timedelta(
arg: list | tuple | range | ArrayLike | Index,
unit: UnitChoices | None = ...,
arg: Sequence[float | timedelta]
| list[str | float | timedelta]
| tuple[str | float | timedelta, ...]
| range
| ArrayLike
| Index,
unit: TimeDeltaUnitChoices | None = ...,
errors: DateTimeErrorChoices = ...,
) -> TimedeltaIndex: ...
8 changes: 7 additions & 1 deletion pandas-stubs/tseries/frequencies.pyi
Original file line number Diff line number Diff line change
@@ -1,6 +1,12 @@
from pandas import (
DatetimeIndex,
Series,
TimedeltaIndex,
)

from pandas.tseries.offsets import DateOffset as DateOffset

def get_period_alias(offset_str: str) -> str | None: ...
def to_offset(freq) -> DateOffset | None: ...
def get_offset(name: str) -> DateOffset: ...
def infer_freq(index) -> str | None: ...
def infer_freq(index: Series | DatetimeIndex | TimedeltaIndex) -> str | None: ...
Loading