UNPKG

nodejs-polars

Version:

Polars: Blazingly fast DataFrames in Rust, Python, Node.js, R and SQL

68 lines (67 loc) 2.62 kB
import { Expr } from "./expr"; export interface When { /** Values to return in case of the predicate being `true`.*/ then(expr: Expr): Then; } export interface Then { /** Start another when, then, otherwise layer. */ when(predicate: Expr): ChainedWhen; /** Values to return in case of the predicate being `false`. */ otherwise(expr: Expr): Expr; } export interface ChainedWhen { /** Values to return in case of the predicate being `true`. */ then(expr: Expr): ChainedThen; } export interface ChainedThen { /** Start another when, then, otherwise layer. */ when(predicate: Expr): ChainedWhen; /** Values to return in case of the predicate being `true`. */ then(expr: Expr): ChainedThen; /** Values to return in case of the predicate being `false`. */ otherwise(expr: Expr): Expr; } /** * Start a when, then, otherwise expression. * * @example * ``` * // Below we add a column with the value 1, where column "foo" > 2 and the value -1 where it isn't. * > df = pl.DataFrame({"foo": [1, 3, 4], "bar": [3, 4, 0]}) * > df.withColumn(pl.when(pl.col("foo").gt(2)).then(pl.lit(1)).otherwise(pl.lit(-1))) * shape: (3, 3) * ┌─────┬─────┬─────────┐ * │ foo ┆ bar ┆ literal │ * │ --- ┆ --- ┆ --- │ * │ i64 ┆ i64 ┆ i32 │ * ╞═════╪═════╪═════════╡ * │ 1 ┆ 3 ┆ -1 │ * ├╌╌╌╌╌┼╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌┤ * │ 3 ┆ 4 ┆ 1 │ * ├╌╌╌╌╌┼╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌┤ * │ 4 ┆ 0 ┆ 1 │ * └─────┴─────┴─────────┘ * * // Or with multiple `when, thens` chained: * > df.with_column( * ... pl.when(pl.col("foo").gt(2)) * ... .then(1) * ... .when(pl.col("bar").gt(2)) * ... .then(4) * ... .otherwise(-1) * ... ) * shape: (3, 3) * ┌─────┬─────┬─────────┐ * │ foo ┆ bar ┆ literal │ * │ --- ┆ --- ┆ --- │ * │ i64 ┆ i64 ┆ i32 │ * ╞═════╪═════╪═════════╡ * │ 1 ┆ 3 ┆ 4 │ * ├╌╌╌╌╌┼╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌┤ * │ 3 ┆ 4 ┆ 1 │ * ├╌╌╌╌╌┼╌╌╌╌╌┼╌╌╌╌╌╌╌╌╌┤ * │ 4 ┆ 0 ┆ 1 │ * └─────┴─────┴─────────┘ * ``` */ export declare function when(expr: Expr): When;