team-10/venv/Lib/site-packages/narwhals/_dask/selectors.py

35 lines
1.1 KiB
Python
Raw Normal View History

2025-08-02 02:00:33 +02:00
from __future__ import annotations
from typing import TYPE_CHECKING
from narwhals._compliant import CompliantSelector, LazySelectorNamespace
from narwhals._dask.expr import DaskExpr
if TYPE_CHECKING:
import dask.dataframe.dask_expr as dx # noqa: F401
from narwhals._compliant.typing import ScalarKwargs
from narwhals._dask.dataframe import DaskLazyFrame # noqa: F401
class DaskSelectorNamespace(LazySelectorNamespace["DaskLazyFrame", "dx.Series"]):
@property
def _selector(self) -> type[DaskSelector]:
return DaskSelector
class DaskSelector(CompliantSelector["DaskLazyFrame", "dx.Series"], DaskExpr): # type: ignore[misc]
_depth: int = 0
_scalar_kwargs: ScalarKwargs = {} # noqa: RUF012
_function_name: str = "selector"
def _to_expr(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,
version=self._version,
)