Files
Buffteks-Website/buffteks/lib/python3.12/site-packages/narwhals/_dask/selectors.py
2025-05-08 21:10:14 -05:00

57 lines
1.9 KiB
Python

from __future__ import annotations
from typing import TYPE_CHECKING
from narwhals._compliant import CompliantSelector
from narwhals._compliant import LazySelectorNamespace
from narwhals._dask.expr import DaskExpr
if TYPE_CHECKING:
try:
import dask.dataframe.dask_expr as dx
except ModuleNotFoundError:
import dask_expr as dx
from typing_extensions import Self
from narwhals._compliant import EvalNames
from narwhals._compliant import EvalSeries
from narwhals._dask.dataframe import DaskLazyFrame
from narwhals.utils import _FullContext
class DaskSelectorNamespace(LazySelectorNamespace["DaskLazyFrame", "dx.Series"]): # pyright: ignore[reportInvalidTypeArguments]
def _selector(
self,
call: EvalSeries[DaskLazyFrame, dx.Series], # pyright: ignore[reportInvalidTypeForm]
evaluate_output_names: EvalNames[DaskLazyFrame],
/,
) -> DaskSelector:
return DaskSelector(
call,
depth=0,
function_name="selector",
evaluate_output_names=evaluate_output_names,
alias_output_names=None,
backend_version=self._backend_version,
version=self._version,
)
def __init__(self: Self, context: _FullContext, /) -> None:
self._implementation = context._implementation
self._backend_version = context._backend_version
self._version = context._version
class DaskSelector(CompliantSelector["DaskLazyFrame", "dx.Series"], DaskExpr): # type: ignore[misc]
def _to_expr(self: Self) -> DaskExpr:
return DaskExpr(
self._call,
depth=self._depth,
function_name=self._function_name,
evaluate_output_names=self._evaluate_output_names,
alias_output_names=self._alias_output_names,
backend_version=self._backend_version,
version=self._version,
)