o
    $&]i«'  ã                   @  sî   d dl mZ d dlmZmZmZ d dlmZmZ d dl	m
Z
 d dlmZ er>d dlmZ d dlmZ d dlmZ d d	lmZ G d
d„ deƒZd(dd„Zd)dd„Zd*dd„Zd*dd„Zd*dd„Zd*dd„Zd*dd„Z		 d+d,d%d&„Zg d'¢ZdS )-é    )Úannotations)ÚTYPE_CHECKINGÚAnyÚNoReturn)ÚExprKindÚExprNode)Úflatten)ÚExpr)ÚIterable)Útimezone)ÚDType)ÚTimeUnitc                   @  sR   e Zd Zddd„Zddd„Zdd	d
„Zddd„Zddd„Zddd„Zddd„Z	dS )ÚSelectorÚreturnr	   c                 C  s
   t | jŽ S ©N)r	   Ú_nodes)Úself© r   úP/var/www/html/IGF-ODF-V3/venv/lib/python3.10/site-packages/narwhals/selectors.pyÚ_to_expr   s   
zSelector._to_exprÚotherr   c                 C  s2   t |tƒrd}t|ƒ‚|  ¡  ttjd|dd¡S )Nz=unsupported operand type(s) for op: ('Selector' + 'Selector')Ú__add__T©Ú
str_as_lit)Ú
isinstancer   Ú	TypeErrorr   Ú_append_noder   r   ÚELEMENTWISE)r   r   Úmsgr   r   r   r      s   
ÿzSelector.__add__c              	   C  ó@   t |tƒr|  ttjd|ddd¡S |  ¡  ttjd|dd¡S )NÚ__or__T©r   Úallow_multi_outputr   ©r   r   r   r   r   r   r   ©r   r   r   r   r   r       ó   
ûÿ	ÿzSelector.__or__c              	   C  r   )NÚ__and__Tr!   r   r#   r$   r   r   r   r&   ,   r%   zSelector.__and__r   c                 C  ó   t ‚r   ©ÚNotImplementedErrorr$   r   r   r   Ú__rsub__;   ó   zSelector.__rsub__c                 C  r'   r   r(   r$   r   r   r   Ú__rand__>   r+   zSelector.__rand__c                 C  r'   r   r(   r$   r   r   r   Ú__ror__A   r+   zSelector.__ror__N)r   r	   )r   r   r   r	   )r   r   r   r   )
Ú__name__Ú
__module__Ú__qualname__r   r   r    r&   r*   r,   r-   r   r   r   r   r      s    





r   Údtypesú3DType | type[DType] | Iterable[DType | type[DType]]r   c                  G  s   t | ƒ}tttjd|dƒS )aj  Select columns based on their dtype.

    Arguments:
        dtypes: one or data types to select

    Examples:
        >>> import pyarrow as pa
        >>> import narwhals as nw
        >>> import narwhals.selectors as ncs
        >>> df_native = pa.table({"a": [1, 2], "b": ["x", "y"], "c": [4.1, 2.3]})
        >>> df = nw.from_native(df_native)

        Let's select int64 and float64  dtypes and multiply each value by 2:

        >>> df.select(ncs.by_dtype(nw.Int64, nw.Float64) * 2).to_native()
        pyarrow.Table
        a: int64
        c: double
        ----
        a: [[2,4]]
        c: [[8.2,4.6]]
    zselectors.by_dtype)r1   )r   r   r   r   ÚSELECTOR)r1   Ú	flattenedr   r   r   Úby_dtypeE   s   r5   ÚpatternÚstrc                 C  s   t ttjd| dƒS )aw  Select all columns that match the given regex pattern.

    Arguments:
        pattern: A valid regular expression pattern.

    Examples:
        >>> import pandas as pd
        >>> import narwhals as nw
        >>> import narwhals.selectors as ncs
        >>> df_native = pd.DataFrame(
        ...     {"bar": [123, 456], "baz": [2.0, 5.5], "zap": [0, 1]}
        ... )
        >>> df = nw.from_native(df_native)

        Let's select column names containing an 'a', preceded by a character that is not 'z':

        >>> df.select(ncs.matches("[^z]a")).to_native()
           bar  baz
        0  123  2.0
        1  456  5.5
    zselectors.matches©r6   ©r   r   r   r3   r8   r   r   r   Úmatches`   s   r:   c                   C  ó   t ttjdƒƒS )uÆ  Select numeric columns.

    Examples:
        >>> import polars as pl
        >>> import narwhals as nw
        >>> import narwhals.selectors as ncs
        >>> df_native = pl.DataFrame({"a": [1, 2], "b": ["x", "y"], "c": [4.1, 2.3]})
        >>> df = nw.from_native(df_native)

        Let's select numeric dtypes and multiply each value by 2:

        >>> df.select(ncs.numeric() * 2).to_native()
        shape: (2, 2)
        â”Œâ”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”
        â”‚ a   â”† c   â”‚
        â”‚ --- â”† --- â”‚
        â”‚ i64 â”† f64 â”‚
        â•žâ•â•â•â•â•â•ªâ•â•â•â•â•â•¡
        â”‚ 2   â”† 8.2 â”‚
        â”‚ 4   â”† 4.6 â”‚
        â””â”€â”€â”€â”€â”€â”´â”€â”€â”€â”€â”€â”˜
    zselectors.numericr9   r   r   r   r   Únumericy   ó   r<   c                   C  r;   )u}  Select boolean columns.

    Examples:
        >>> import polars as pl
        >>> import narwhals as nw
        >>> import narwhals.selectors as ncs
        >>> df_native = pl.DataFrame({"a": [1, 2], "b": ["x", "y"], "c": [False, True]})
        >>> df = nw.from_native(df_native)

        Let's select boolean dtypes:

        >>> df.select(ncs.boolean())
        â”Œâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
        |Narwhals DataFrame|
        |------------------|
        |  shape: (2, 1)   |
        |  â”Œâ”€â”€â”€â”€â”€â”€â”€â”       |
        |  â”‚ c     â”‚       |
        |  â”‚ ---   â”‚       |
        |  â”‚ bool  â”‚       |
        |  â•žâ•â•â•â•â•â•â•â•¡       |
        |  â”‚ false â”‚       |
        |  â”‚ true  â”‚       |
        |  â””â”€â”€â”€â”€â”€â”€â”€â”˜       |
        â””â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”˜
    zselectors.booleanr9   r   r   r   r   Úboolean“   s   r>   c                   C  r;   )uG  Select string columns.

    Examples:
        >>> import polars as pl
        >>> import narwhals as nw
        >>> import narwhals.selectors as ncs
        >>> df_native = pl.DataFrame({"a": [1, 2], "b": ["x", "y"], "c": [False, True]})
        >>> df = nw.from_native(df_native)

        Let's select string dtypes:

        >>> df.select(ncs.string()).to_native()
        shape: (2, 1)
        â”Œâ”€â”€â”€â”€â”€â”
        â”‚ b   â”‚
        â”‚ --- â”‚
        â”‚ str â”‚
        â•žâ•â•â•â•â•â•¡
        â”‚ x   â”‚
        â”‚ y   â”‚
        â””â”€â”€â”€â”€â”€â”˜
    zselectors.stringr9   r   r   r   r   Ústring±   r=   r?   c                   C  r;   )uÓ  Select categorical columns.

    Examples:
        >>> import polars as pl
        >>> import narwhals as nw
        >>> import narwhals.selectors as ncs
        >>> df_native = pl.DataFrame({"a": [1, 2], "b": ["x", "y"], "c": [False, True]})

        Let's convert column "b" to categorical, and then select categorical dtypes:

        >>> df = nw.from_native(df_native).with_columns(
        ...     b=nw.col("b").cast(nw.Categorical())
        ... )
        >>> df.select(ncs.categorical()).to_native()
        shape: (2, 1)
        â”Œâ”€â”€â”€â”€â”€â”
        â”‚ b   â”‚
        â”‚ --- â”‚
        â”‚ cat â”‚
        â•žâ•â•â•â•â•â•¡
        â”‚ x   â”‚
        â”‚ y   â”‚
        â””â”€â”€â”€â”€â”€â”˜
    zselectors.categoricalr9   r   r   r   r   ÚcategoricalË   s   r@   c                   C  r;   )a¯  Select all columns.

    Examples:
        >>> import pandas as pd
        >>> import narwhals as nw
        >>> import narwhals.selectors as ncs
        >>> df_native = pd.DataFrame({"a": [1, 2], "b": ["x", "y"], "c": [False, True]})
        >>> df = nw.from_native(df_native)

        Let's select all dtypes:

        >>> df.select(ncs.all()).to_native()
           a  b      c
        0  1  x  False
        1  2  y   True
    zselectors.allr9   r   r   r   r   Úallç   s   rA   N©Ú*NÚ	time_unitú$TimeUnit | Iterable[TimeUnit] | NoneÚ	time_zoneú7str | timezone | Iterable[str | timezone | None] | Nonec                 C  s   t ttjd| |dƒS )aé  Select all datetime columns, optionally filtering by time unit/zone.

    Arguments:
        time_unit: One (or more) of the allowed timeunit precision strings, "ms", "us",
            "ns" and "s". Omit to select columns with any valid timeunit.
        time_zone: Specify which timezone(s) to select

            * One or more timezone strings, as defined in zoneinfo (to see valid options
                run `import zoneinfo; zoneinfo.available_timezones()` for a full list).
            * Set `None` to select Datetime columns that do not have a timezone.
            * Set `"*"` to select Datetime columns that have *any* timezone.

    Examples:
        >>> from datetime import datetime, timezone
        >>> import pyarrow as pa
        >>> import narwhals as nw
        >>> import narwhals.selectors as ncs
        >>>
        >>> utc_tz = timezone.utc
        >>> data = {
        ...     "tstamp_utc": [
        ...         datetime(2023, 4, 10, 12, 14, 16, 999000, tzinfo=utc_tz),
        ...         datetime(2025, 8, 25, 14, 18, 22, 666000, tzinfo=utc_tz),
        ...     ],
        ...     "tstamp": [
        ...         datetime(2000, 11, 20, 18, 12, 16, 600000),
        ...         datetime(2020, 10, 30, 10, 20, 25, 123000),
        ...     ],
        ...     "numeric": [3.14, 6.28],
        ... }
        >>> df_native = pa.table(data)
        >>> df_nw = nw.from_native(df_native)
        >>> df_nw.select(ncs.datetime()).to_native()
        pyarrow.Table
        tstamp_utc: timestamp[us, tz=UTC]
        tstamp: timestamp[us]
        ----
        tstamp_utc: [[2023-04-10 12:14:16.999000Z,2025-08-25 14:18:22.666000Z]]
        tstamp: [[2000-11-20 18:12:16.600000,2020-10-30 10:20:25.123000]]

        Select only datetime columns that have any time_zone specification:

        >>> df_nw.select(ncs.datetime(time_zone="*")).to_native()
        pyarrow.Table
        tstamp_utc: timestamp[us, tz=UTC]
        ----
        tstamp_utc: [[2023-04-10 12:14:16.999000Z,2025-08-25 14:18:22.666000Z]]
    zselectors.datetime©rD   rF   r9   rH   r   r   r   Údatetimeû   s   4üÿrI   )rA   r>   r5   r@   rI   r:   r<   r?   )r1   r2   r   r   )r6   r7   r   r   )r   r   )NrB   )rD   rE   rF   rG   r   r   )Ú
__future__r   Útypingr   r   r   Únarwhals._expression_parsingr   r   Únarwhals._utilsr   Únarwhals.exprr	   Úcollections.abcr
   rI   r   Únarwhals.dtypesr   Únarwhals.typingr   r   r5   r:   r<   r>   r?   r@   rA   Ú__all__r   r   r   r   Ú<module>   s,    
4





þ>