§
    ­-Phýy  ã                  ó„   — d dl mZ d dlmZmZmZ erd dlmZ d dlm	Z	  edd¬¦  «        Z
 G d„ d	ee
         ¦  «        Zd
S )é    )Úannotations)ÚTYPE_CHECKINGÚGenericÚTypeVar)ÚExpr)ÚTimeUnitÚExprTr   )Úboundc                  óÈ   — e Zd Zd%d„Zd&d„Zd&d„Zd&d„Zd&d	„Zd&d
„Zd&d„Z	d&d„Z
d&d„Zd&d„Zd&d„Zd&d„Zd&d„Zd&d„Zd&d„Zd&d„Zd&d„Zd&d„Zd'd„Zd(d„Zd)d„Zd*d+d!„Zd,d#„Zd$S )-ÚExprDateTimeNamespaceÚexprr	   ÚreturnÚNonec                ó   — || _         d S ©N)Ú_expr)Úselfr   s     úP/var/www/html/test/jupyter/venv/lib/python3.11/site-packages/narwhals/expr_dt.pyÚ__init__zExprDateTimeNamespace.__init__   s   € ØˆŒ
ˆ
ˆ
ó    c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )u¨  Extract the date from underlying DateTime representation.

        Returns:
            A new expression.

        Raises:
            NotImplementedError: If pandas default backend is being used.

        Examples:
            >>> from datetime import datetime
            >>> import polars as pl
            >>> import narwhals as nw
            >>> df_native = pl.DataFrame(
            ...     {"a": [datetime(2012, 1, 7, 10), datetime(2027, 12, 13)]}
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.select(nw.col("a").dt.date()).to_native()
            shape: (2, 1)
            â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
            â”‚ a          â”‚
            â”‚ ---        â”‚
            â”‚ date       â”‚
            â•žâ•â•â•â•â•â•â•â•â•â•â•â•â•¡
            â”‚ 2012-01-07 â”‚
            â”‚ 2027-12-13 â”‚
            â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   Ú_to_compliant_exprÚdtÚdate©Úplxr   s    €r   ú<lambda>z,ExprDateTimeNamespace.date.<locals>.<lambda>-   ó&   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×BÒBÑDÔD€ r   ©r   Ú_with_elementwise_op©r   s   `r   r   zExprDateTimeNamespace.date   s+   ø€ ð8 Œz×.Ò.ØDÐDÐDÐDñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )u_  Extract year from underlying DateTime representation.

        Returns the year number in the calendar date.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime
            >>> import pandas as pd
            >>> import narwhals as nw
            >>> df_native = pd.DataFrame(
            ...     {"a": [datetime(1978, 6, 1), datetime(2065, 1, 1)]}
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(nw.col("a").dt.year().alias("year"))
            â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
            |Narwhals DataFrame|
            |------------------|
            |           a  year|
            |0 1978-06-01  1978|
            |1 2065-01-01  2065|
            â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Úyearr   s    €r   r   z,ExprDateTimeNamespace.year.<locals>.<lambda>J   r   r   r    r"   s   `r   r%   zExprDateTimeNamespace.year0   s+   ø€ ð2 Œz×.Ò.ØDÐDÐDÐDñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )aõ  Extract month from underlying DateTime representation.

        Returns the month number starting from 1. The return value ranges from 1 to 12.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime
            >>> import pyarrow as pa
            >>> import narwhals as nw
            >>> df_native = pa.table({"a": [datetime(1978, 6, 1), datetime(2065, 1, 1)]})
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(nw.col("a").dt.month().alias("month")).to_native()
            pyarrow.Table
            a: timestamp[us]
            month: int64
            ----
            a: [[1978-06-01 00:00:00.000000,2065-01-01 00:00:00.000000]]
            month: [[6,1]]
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Úmonthr   s    €r   r   z-ExprDateTimeNamespace.month.<locals>.<lambda>d   s&   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×CÒCÑEÔE€ r   r    r"   s   `r   r(   zExprDateTimeNamespace.monthM   s+   ø€ ð, Œz×.Ò.ØEÐEÐEÐEñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )a  Extract day from underlying DateTime representation.

        Returns the day of month starting from 1. The return value ranges from 1 to 31. (The last day of month differs by months.)

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime
            >>> import pyarrow as pa
            >>> import narwhals as nw
            >>> df_native = pa.table({"a": [datetime(1978, 6, 1), datetime(2065, 1, 1)]})
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(nw.col("a").dt.day().alias("day")).to_native()
            pyarrow.Table
            a: timestamp[us]
            day: int64
            ----
            a: [[1978-06-01 00:00:00.000000,2065-01-01 00:00:00.000000]]
            day: [[1,1]]
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Údayr   s    €r   r   z+ExprDateTimeNamespace.day.<locals>.<lambda>~   s&   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×AÒAÑCÔC€ r   r    r"   s   `r   r+   zExprDateTimeNamespace.dayg   s+   ø€ ð, Œz×.Ò.ØCÐCÐCÐCñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )uÃ  Extract hour from underlying DateTime representation.

        Returns the hour number from 0 to 23.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime
            >>> import polars as pl
            >>> import narwhals as nw
            >>> df_native = pl.DataFrame(
            ...     {"a": [datetime(1978, 1, 1, 1), datetime(2065, 1, 1, 10)]}
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(nw.col("a").dt.hour().alias("hour"))
            â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
            |      Narwhals DataFrame      |
            |------------------------------|
            |shape: (2, 2)                 |
            |â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”|
            |â”‚ a                   â”† hour â”‚|
            |â”‚ ---                 â”† ---  â”‚|
            |â”‚ datetime[Î¼s]        â”† i8   â”‚|
            |â•žâ•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•ªâ•â•â•â•â•â•â•¡|
            |â”‚ 1978-01-01 01:00:00 â”† 1    â”‚|
            |â”‚ 2065-01-01 10:00:00 â”† 10   â”‚|
            |â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”´â”€â”€â”€â”€â”€â”€â”˜|
            â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Úhourr   s    €r   r   z,ExprDateTimeNamespace.hour.<locals>.<lambda>¡   r   r   r    r"   s   `r   r.   zExprDateTimeNamespace.hour   s+   ø€ ð> Œz×.Ò.ØDÐDÐDÐDñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )aÁ  Extract minutes from underlying DateTime representation.

        Returns the minute number from 0 to 59.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime
            >>> import pandas as pd
            >>> import narwhals as nw
            >>> df_native = pd.DataFrame(
            ...     {"a": [datetime(1978, 1, 1, 1, 1), datetime(2065, 1, 1, 10, 20)]}
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(nw.col("a").dt.minute().alias("minute")).to_native()
                                a  minute
            0 1978-01-01 01:01:00       1
            1 2065-01-01 10:20:00      20
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Úminuter   s    €r   r   z.ExprDateTimeNamespace.minute.<locals>.<lambda>º   ó&   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×DÒDÑFÔF€ r   r    r"   s   `r   r1   zExprDateTimeNamespace.minute¤   s+   ø€ ð* Œz×.Ò.ØFÐFÐFÐFñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )a_  Extract seconds from underlying DateTime representation.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime
            >>> import pyarrow as pa
            >>> import narwhals as nw
            >>> df_native = pa.table(
            ...     {
            ...         "a": [
            ...             datetime(1978, 1, 1, 1, 1, 1),
            ...             datetime(2065, 1, 1, 10, 20, 30),
            ...         ]
            ...     }
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(nw.col("a").dt.second().alias("second")).to_native()
            pyarrow.Table
            a: timestamp[us]
            second: int64
            ----
            a: [[1978-01-01 01:01:01.000000,2065-01-01 10:20:30.000000]]
            second: [[1,30]]
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Úsecondr   s    €r   r   z.ExprDateTimeNamespace.second.<locals>.<lambda>Ù   r2   r   r    r"   s   `r   r5   zExprDateTimeNamespace.second½   s+   ø€ ð6 Œz×.Ò.ØFÐFÐFÐFñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )a¨  Extract milliseconds from underlying DateTime representation.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime
            >>> import pyarrow as pa
            >>> import narwhals as nw
            >>> df_native = pa.table(
            ...     {
            ...         "a": [
            ...             datetime(1978, 1, 1, 1, 1, 1, 0),
            ...             datetime(2065, 1, 1, 10, 20, 30, 67000),
            ...         ]
            ...     }
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(
            ...     nw.col("a").dt.millisecond().alias("millisecond")
            ... ).to_native()
            pyarrow.Table
            a: timestamp[us]
            millisecond: int64
            ----
            a: [[1978-01-01 01:01:01.000000,2065-01-01 10:20:30.067000]]
            millisecond: [[0,67]]
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Úmillisecondr   s    €r   r   z3ExprDateTimeNamespace.millisecond.<locals>.<lambda>ú   ó&   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×IÒIÑKÔK€ r   r    r"   s   `r   r8   z!ExprDateTimeNamespace.millisecondÜ   ó+   ø€ ð: Œz×.Ò.ØKÐKÐKÐKñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )a«  Extract microseconds from underlying DateTime representation.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime
            >>> import pyarrow as pa
            >>> import narwhals as nw
            >>> df_native = pa.table(
            ...     {
            ...         "a": [
            ...             datetime(1978, 1, 1, 1, 1, 1, 0),
            ...             datetime(2065, 1, 1, 10, 20, 30, 67000),
            ...         ]
            ...     }
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(
            ...     nw.col("a").dt.microsecond().alias("microsecond")
            ... ).to_native()
            pyarrow.Table
            a: timestamp[us]
            microsecond: int64
            ----
            a: [[1978-01-01 01:01:01.000000,2065-01-01 10:20:30.067000]]
            microsecond: [[0,67000]]
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Úmicrosecondr   s    €r   r   z3ExprDateTimeNamespace.microsecond.<locals>.<lambda>  r9   r   r    r"   s   `r   r=   z!ExprDateTimeNamespace.microsecondý   r:   r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )a©  Extract Nanoseconds from underlying DateTime representation.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime
            >>> import pyarrow as pa
            >>> import narwhals as nw
            >>> df_native = pa.table(
            ...     {
            ...         "a": [
            ...             datetime(1978, 1, 1, 1, 1, 1, 0),
            ...             datetime(2065, 1, 1, 10, 20, 30, 67000),
            ...         ]
            ...     }
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(
            ...     nw.col("a").dt.nanosecond().alias("nanosecond")
            ... ).to_native()
            pyarrow.Table
            a: timestamp[us]
            nanosecond: int64
            ----
            a: [[1978-01-01 01:01:01.000000,2065-01-01 10:20:30.067000]]
            nanosecond: [[0,67000000]]
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Ú
nanosecondr   s    €r   r   z2ExprDateTimeNamespace.nanosecond.<locals>.<lambda><  s&   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×HÒHÑJÔJ€ r   r    r"   s   `r   r@   z ExprDateTimeNamespace.nanosecond  s+   ø€ ð: Œz×.Ò.ØJÐJÐJÐJñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )um  Get ordinal day.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime
            >>> import pandas as pd
            >>> import narwhals as nw
            >>> df_native = pd.DataFrame(
            ...     {"a": [datetime(2020, 1, 1), datetime(2020, 8, 3)]}
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(a_ordinal_day=nw.col("a").dt.ordinal_day())
            â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
            |    Narwhals DataFrame     |
            |---------------------------|
            |           a  a_ordinal_day|
            |0 2020-01-01              1|
            |1 2020-08-03            216|
            â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Úordinal_dayr   s    €r   r   z3ExprDateTimeNamespace.ordinal_day.<locals>.<lambda>W  r9   r   r    r"   s   `r   rC   z!ExprDateTimeNamespace.ordinal_day?  s+   ø€ ð. Œz×.Ò.ØKÐKÐKÐKñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )uŸ  Extract the week day from the underlying Date representation.

        Returns:
            Returns the ISO weekday number where monday = 1 and sunday = 7

        Examples:
            >>> from datetime import datetime
            >>> import pandas as pd
            >>> import narwhals as nw
            >>> df_native = pd.DataFrame(
            ...     {"a": [datetime(2020, 1, 1), datetime(2020, 8, 3)]}
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(a_week_day=nw.col("a").dt.weekday())
            â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
            |   Narwhals DataFrame   |
            |------------------------|
            |           a  a_week_day|
            |0 2020-01-01           3|
            |1 2020-08-03           1|
            â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Úweekdayr   s    €r   r   z/ExprDateTimeNamespace.weekday.<locals>.<lambda>r  s&   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×EÒEÑGÔG€ r   r    r"   s   `r   rF   zExprDateTimeNamespace.weekdayZ  s+   ø€ ð. Œz×.Ò.ØGÐGÐGÐGñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )u’  Get total minutes.

        Returns:
            A new expression.

        Notes:
            The function outputs the total minutes in the int dtype by default,
            however, pandas may change the dtype to float when there are missing values,
            consider using `fill_null()` and `cast` in this case.

        Examples:
            >>> from datetime import timedelta
            >>> import polars as pl
            >>> import narwhals as nw
            >>> df_native = pl.DataFrame(
            ...     {"a": [timedelta(minutes=10), timedelta(minutes=20, seconds=40)]}
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(
            ...     a_total_minutes=nw.col("a").dt.total_minutes()
            ... ).to_native()
            shape: (2, 2)
            â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
            â”‚ a            â”† a_total_minutes â”‚
            â”‚ ---          â”† ---             â”‚
            â”‚ duration[Î¼s] â”† i64             â”‚
            â•žâ•â•â•â•â•â•â•â•â•â•â•â•â•â•â•ªâ•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•¡
            â”‚ 10m          â”† 10              â”‚
            â”‚ 20m 40s      â”† 20              â”‚
            â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”´â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Útotal_minutesr   s    €r   r   z5ExprDateTimeNamespace.total_minutes.<locals>.<lambda>–  ó&   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×KÒKÑMÔM€ r   r    r"   s   `r   rI   z#ExprDateTimeNamespace.total_minutesu  ó,   ø€ ð@ Œz×.Ò.ØMÐMÐMÐMñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )u—  Get total seconds.

        Returns:
            A new expression.

        Notes:
            The function outputs the total seconds in the int dtype by default,
            however, pandas may change the dtype to float when there are missing values,
            consider using `fill_null()` and `cast` in this case.

        Examples:
            >>> from datetime import timedelta
            >>> import polars as pl
            >>> import narwhals as nw
            >>> df_native = pl.DataFrame(
            ...     {"a": [timedelta(seconds=10), timedelta(seconds=20, milliseconds=40)]}
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(
            ...     a_total_seconds=nw.col("a").dt.total_seconds()
            ... ).to_native()
            shape: (2, 2)
            â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
            â”‚ a            â”† a_total_seconds â”‚
            â”‚ ---          â”† ---             â”‚
            â”‚ duration[Î¼s] â”† i64             â”‚
            â•žâ•â•â•â•â•â•â•â•â•â•â•â•â•â•â•ªâ•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•¡
            â”‚ 10s          â”† 10              â”‚
            â”‚ 20s 40ms     â”† 20              â”‚
            â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”´â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Útotal_secondsr   s    €r   r   z5ExprDateTimeNamespace.total_seconds.<locals>.<lambda>º  rJ   r   r    r"   s   `r   rN   z#ExprDateTimeNamespace.total_seconds™  rK   r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )u}  Get total milliseconds.

        Returns:
            A new expression.

        Notes:
            The function outputs the total milliseconds in the int dtype by default,
            however, pandas may change the dtype to float when there are missing values,
            consider using `fill_null()` and `cast` in this case.

        Examples:
            >>> from datetime import timedelta
            >>> import polars as pl
            >>> import narwhals as nw
            >>> df_native = pl.DataFrame(
            ...     {
            ...         "a": [
            ...             timedelta(milliseconds=10),
            ...             timedelta(milliseconds=20, microseconds=40),
            ...         ]
            ...     }
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(
            ...     a_total_milliseconds=nw.col("a").dt.total_milliseconds()
            ... ).to_native()
            shape: (2, 2)
            â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
            â”‚ a            â”† a_total_milliseconds â”‚
            â”‚ ---          â”† ---                  â”‚
            â”‚ duration[Î¼s] â”† i64                  â”‚
            â•žâ•â•â•â•â•â•â•â•â•â•â•â•â•â•â•ªâ•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•¡
            â”‚ 10ms         â”† 10                   â”‚
            â”‚ 20040Âµs      â”† 20                   â”‚
            â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”´â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Útotal_millisecondsr   s    €r   r   z:ExprDateTimeNamespace.total_milliseconds.<locals>.<lambda>ã  ó&   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×PÒPÑRÔR€ r   r    r"   s   `r   rQ   z(ExprDateTimeNamespace.total_milliseconds½  s,   ø€ ðJ Œz×.Ò.ØRÐRÐRÐRñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )an  Get total microseconds.

        Returns:
            A new expression.

        Notes:
            The function outputs the total microseconds in the int dtype by default,
            however, pandas may change the dtype to float when there are missing values,
            consider using `fill_null()` and `cast` in this case.

        Examples:
            >>> from datetime import timedelta
            >>> import pyarrow as pa
            >>> import narwhals as nw
            >>> df_native = pa.table(
            ...     {
            ...         "a": [
            ...             timedelta(microseconds=10),
            ...             timedelta(milliseconds=1, microseconds=200),
            ...         ]
            ...     }
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(
            ...     a_total_microseconds=nw.col("a").dt.total_microseconds()
            ... ).to_native()
            pyarrow.Table
            a: duration[us]
            a_total_microseconds: int64
            ----
            a: [[10,1200]]
            a_total_microseconds: [[10,1200]]
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Útotal_microsecondsr   s    €r   r   z:ExprDateTimeNamespace.total_microseconds.<locals>.<lambda>	  rR   r   r    r"   s   `r   rU   z(ExprDateTimeNamespace.total_microsecondsæ  s,   ø€ ðD Œz×.Ò.ØRÐRÐRÐRñ
ô 
ð 	
r   c                ó>   ‡ — ‰ j                              ˆ fd„¦  «        S )aÞ  Get total nanoseconds.

        Returns:
            A new expression.

        Notes:
            The function outputs the total nanoseconds in the int dtype by default,
            however, pandas may change the dtype to float when there are missing values,
            consider using `fill_null()` and `cast` in this case.

        Examples:
            >>> from datetime import timedelta
            >>> import pandas as pd
            >>> import narwhals as nw
            >>> df_native = pd.DataFrame(
            ...     {
            ...         "a": pd.to_datetime(
            ...             [
            ...                 "2024-01-01 00:00:00.000000001",
            ...                 "2024-01-01 00:00:00.000000002",
            ...             ]
            ...         )
            ...     }
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(
            ...     a_diff_total_nanoseconds=nw.col("a").diff().dt.total_nanoseconds()
            ... ).to_native()
                                          a  a_diff_total_nanoseconds
            0 2024-01-01 00:00:00.000000001                       NaN
            1 2024-01-01 00:00:00.000000002                       1.0
        c                óf   •— ‰j                              | ¦  «        j                             ¦   «         S r   )r   r   r   Útotal_nanosecondsr   s    €r   r   z9ExprDateTimeNamespace.total_nanoseconds.<locals>.<lambda>.  s&   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×OÒOÑQÔQ€ r   r    r"   s   `r   rX   z'ExprDateTimeNamespace.total_nanoseconds  s,   ø€ ðB Œz×.Ò.ØQÐQÐQÐQñ
ô 
ð 	
r   ÚformatÚstrc                óB   ‡ ‡— ‰ j                              ˆˆ fd„¦  «        S )u÷
  Convert a Date/Time/Datetime column into a String column with the given format.

        Arguments:
            format: Format to format temporal column with.

        Returns:
            A new expression.

        Notes:
            Unfortunately, different libraries interpret format directives a bit
            differently.

            - Chrono, the library used by Polars, uses `"%.f"` for fractional seconds,
              whereas pandas and Python stdlib use `".%f"`.
            - PyArrow interprets `"%S"` as "seconds, including fractional seconds"
              whereas most other tools interpret it as "just seconds, as 2 digits".
            ---
            Therefore, we make the following adjustments.

            - for pandas-like libraries, we replace `"%S.%f"` with `"%S%.f"`.
            - for PyArrow, we replace `"%S.%f"` with `"%S"`.
            ---
            Workarounds like these don't make us happy, and we try to avoid them as
            much as possible, but here we feel like it's the best compromise.

            If you just want to format a date/datetime Series as a local datetime
            string, and have it work as consistently as possible across libraries,
            we suggest using:

            - `"%Y-%m-%dT%H:%M:%S%.f"` for datetimes
            - `"%Y-%m-%d"` for dates
            ---
            Though note that, even then, different tools may return a different number
            of trailing zeros. Nonetheless, this is probably consistent enough for
            most applications.

            If you have an application where this is not enough, please open an issue
            and let us know.

        Examples:
            >>> from datetime import datetime
            >>> import polars as pl
            >>> import narwhals as nw
            >>> df_native = pl.DataFrame(
            ...     {"a": [datetime(2020, 3, 1), datetime(2020, 5, 1)]}
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.select(nw.col("a").dt.to_string("%Y/%m/%d %H:%M:%S"))
            â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
            |  Narwhals DataFrame   |
            |-----------------------|
            |shape: (2, 1)          |
            |â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”|
            |â”‚ a                   â”‚|
            |â”‚ ---                 â”‚|
            |â”‚ str                 â”‚|
            |â•žâ•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•¡|
            |â”‚ 2020/03/01 00:00:00 â”‚|
            |â”‚ 2020/05/01 00:00:00 â”‚|
            |â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜|
            â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
        c                óh   •— ‰j                              | ¦  «        j                             ‰¦  «        S r   )r   r   r   Ú	to_string)r   rY   r   s    €€r   r   z1ExprDateTimeNamespace.to_string.<locals>.<lambda>q  s(   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×GÒGÈÑOÔO€ r   r    )r   rY   s   ``r   r]   zExprDateTimeNamespace.to_string1  s0   øø€ ð~ Œz×.Ò.ØOÐOÐOÐOÐOñ
ô 
ð 	
r   Ú	time_zoneú
str | Nonec                óB   ‡ ‡— ‰ j                              ˆ ˆfd„¦  «        S )aM  Replace time zone.

        Arguments:
            time_zone: Target time zone.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime, timezone
            >>> import pandas as pd
            >>> import narwhals as nw
            >>> df_native = pd.DataFrame(
            ...     {
            ...         "a": [
            ...             datetime(2024, 1, 1, tzinfo=timezone.utc),
            ...             datetime(2024, 1, 2, tzinfo=timezone.utc),
            ...         ]
            ...     }
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.select(nw.col("a").dt.replace_time_zone("Asia/Kathmandu")).to_native()
                                      a
            0 2024-01-01 00:00:00+05:45
            1 2024-01-02 00:00:00+05:45
        c                óh   •— ‰j                              | ¦  «        j                             ‰¦  «        S r   )r   r   r   Úreplace_time_zone©r   r   r^   s    €€r   r   z9ExprDateTimeNamespace.replace_time_zone.<locals>.<lambda>  ó)   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×OÒOÐPYÑZÔZ€ r   r    )r   r^   s   ``r   rb   z'ExprDateTimeNamespace.replace_time_zonet  s/   øø€ ð6 Œz×.Ò.ØZÐZÐZÐZÐZñ
ô 
ð 	
r   c                óh   ‡ ‡— ‰€d}t          |¦  «        ‚‰ j                             ˆ ˆfd„¦  «        S )aÇ  Convert to a new time zone.

        If converting from a time-zone-naive column, then conversion happens
        as if converting from UTC.

        Arguments:
            time_zone: Target time zone.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import datetime, timezone
            >>> import pandas as pd
            >>> import narwhals as nw
            >>> df_native = pd.DataFrame(
            ...     {
            ...         "a": [
            ...             datetime(2024, 1, 1, tzinfo=timezone.utc),
            ...             datetime(2024, 1, 2, tzinfo=timezone.utc),
            ...         ]
            ...     }
            ... )
            >>> df = nw.from_native(df_native)
            >>> df.select(nw.col("a").dt.convert_time_zone("Asia/Kathmandu")).to_native()
                                      a
            0 2024-01-01 05:45:00+05:45
            1 2024-01-02 05:45:00+05:45
        Nz…Target `time_zone` cannot be `None` in `convert_time_zone`. Please use `replace_time_zone(None)` if you want to remove the time zone.c                óh   •— ‰j                              | ¦  «        j                             ‰¦  «        S r   )r   r   r   Úconvert_time_zonerc   s    €€r   r   z9ExprDateTimeNamespace.convert_time_zone.<locals>.<lambda>µ  rd   r   )Ú	TypeErrorr   r!   )r   r^   Úmsgs   `` r   rg   z'ExprDateTimeNamespace.convert_time_zone“  sI   øø€ ð< Ðð ZˆCÝ˜C‘.”.Ð ØŒz×.Ò.ØZÐZÐZÐZÐZñ
ô 
ð 	
r   ÚusÚ	time_unitr   c                ót   ‡ ‡— ‰dvrd‰›d}t          |¦  «        ‚‰ j                             ˆ ˆfd„¦  «        S )uã  Return a timestamp in the given time unit.

        Arguments:
            time_unit: One of
                - 'ns': nanosecond.
                - 'us': microsecond.
                - 'ms': millisecond.

        Returns:
            A new expression.

        Examples:
            >>> from datetime import date
            >>> import polars as pl
            >>> import narwhals as nw
            >>> df_native = pl.DataFrame({"date": [date(2001, 1, 1), None]})
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(nw.col("date").dt.timestamp("ms").alias("timestamp_ms"))
            â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
            |     Narwhals DataFrame      |
            |-----------------------------|
            |shape: (2, 2)                |
            |â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”|
            |â”‚ date       â”† timestamp_ms â”‚|
            |â”‚ ---        â”† ---          â”‚|
            |â”‚ date       â”† i64          â”‚|
            |â•žâ•â•â•â•â•â•â•â•â•â•â•â•â•ªâ•â•â•â•â•â•â•â•â•â•â•â•â•â•â•¡|
            |â”‚ 2001-01-01 â”† 978307200000 â”‚|
            |â”‚ null       â”† null         â”‚|
            |â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”´â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜|
            â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
        >   ÚmsÚnsrj   z=invalid `time_unit`

Expected one of {'ns', 'us', 'ms'}, got ú.c                óh   •— ‰j                              | ¦  «        j                             ‰¦  «        S r   )r   r   r   Ú	timestamp)r   r   rk   s    €€r   r   z1ExprDateTimeNamespace.timestamp.<locals>.<lambda>à  s(   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×GÒGÈ	ÑRÔR€ r   )Ú
ValueErrorr   r!   )r   rk   ri   s   `` r   rq   zExprDateTimeNamespace.timestamp¸  sj   øø€ ðB Ð.Ð.Ð.ðPØAJðPð Pð Pð õ ˜S‘/”/Ð!ØŒz×.Ò.ØRÐRÐRÐRÐRñ
ô 
ð 	
r   Úeveryc                óB   ‡ ‡— ‰ j                              ˆˆ fd„¦  «        S )uµ  Divide the date/datetime range into buckets.

        Arguments:
            every: Length of bucket. Must be of form `<multiple><unit>`,
                where `multiple` is a positive integer and `unit` is one of

                - 'ns': nanosecond.
                - 'us': microsecond.
                - 'ms': millisecond.
                - 's': second.
                - 'm': minute.
                - 'h': hour.
                - 'd': day.
                - 'mo': month.
                - 'q': quarter.
                - 'y': year.

        Returns:
            Expression of data type `Date` or `Datetime`.

        Examples:
            >>> from datetime import datetime
            >>> import polars as pl
            >>> import narwhals as nw
            >>> df_native = pl.DataFrame({"datetime": [datetime(2021, 3, 1, 12, 34)]})
            >>> df = nw.from_native(df_native)
            >>> df.with_columns(
            ...     nw.col("datetime").dt.truncate("1h").alias("datetime_trunc")
            ... )
            â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
            |             Narwhals DataFrame              |
            |---------------------------------------------|
            |shape: (1, 2)                                |
            |â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”|
            |â”‚ datetime            â”† datetime_trunc      â”‚|
            |â”‚ ---                 â”† ---                 â”‚|
            |â”‚ datetime[Î¼s]        â”† datetime[Î¼s]        â”‚|
            |â•žâ•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•ªâ•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•¡|
            |â”‚ 2021-03-01 12:34:00 â”† 2021-03-01 12:00:00 â”‚|
            |â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”´â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜|
            â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
        c                óh   •— ‰j                              | ¦  «        j                             ‰¦  «        S r   )r   r   r   Útruncate)r   rs   r   s    €€r   r   z0ExprDateTimeNamespace.truncate.<locals>.<lambda>  s(   ø€ ˜œ
×5Ò5°cÑ:Ô:Ô=×FÒFÀuÑMÔM€ r   r    )r   rs   s   ``r   rv   zExprDateTimeNamespace.truncateã  s0   øø€ ðV Œz×.Ò.ØMÐMÐMÐMÐMñ
ô 
ð 	
r   N)r   r	   r   r   )r   r	   )rY   rZ   r   r	   )r^   r_   r   r	   )r^   rZ   r   r	   )rj   )rk   r   r   r	   )rs   rZ   r   r	   )Ú__name__Ú
__module__Ú__qualname__r   r   r%   r(   r+   r.   r1   r5   r8   r=   r@   rC   rF   rI   rN   rQ   rU   rX   r]   rb   rg   rq   rv   © r   r   r   r      sö  € € € € € ðð ð ð ð
ð 
ð 
ð 
ð@
ð 
ð 
ð 
ð:
ð 
ð 
ð 
ð4
ð 
ð 
ð 
ð4!
ð !
ð !
ð !
ðF
ð 
ð 
ð 
ð2
ð 
ð 
ð 
ð>
ð 
ð 
ð 
ðB
ð 
ð 
ð 
ðB
ð 
ð 
ð 
ðB
ð 
ð 
ð 
ð6
ð 
ð 
ð 
ð6"
ð "
ð "
ð "
ðH"
ð "
ð "
ð "
ðH'
ð '
ð '
ð '
ðR$
ð $
ð $
ð $
ðL#
ð #
ð #
ð #
ðJA
ð A
ð A
ð A
ðF
ð 
ð 
ð 
ð>#
ð #
ð #
ð #
ðJ)
ð )
ð )
ð )
ð )
ðV-
ð -
ð -
ð -
ð -
ð -
r   r   N)Ú
__future__r   Útypingr   r   r   Únarwhals.exprr   Únarwhals.typingr   r	   r   rz   r   r   ú<module>r      s·   ðØ "Ð "Ð "Ð "Ð "Ð "à 2Ð 2Ð 2Ð 2Ð 2Ð 2Ð 2Ð 2Ð 2Ð 2àð )Ø"Ð"Ð"Ð"Ð"Ð"Ø(Ð(Ð(Ð(Ð(Ð(àˆ˜vÐ&Ñ&Ô&€ðD
ð D
ð D
ð D
ð D
˜G EœNñ D
ô D
ð D
ð D
ð D
r   