条件#
函数 |
描述 |
|---|---|
返回提供的值/列中的第一个非空值。 |
|
返回表达式列表中的最大值。 |
|
如果作为第一个参数提供的布尔条件评估为真,则返回expr1,否则返回expr2。 |
|
如果表达式的值为NULL,则返回一个替代值。 |
|
返回表达式列表中的最小值。 |
|
如果两个表达式相等,则返回NULL,否则返回第一个表达式。 |
COALESCE#
返回提供的值/列中的第一个非空值。
示例:
df = pl.DataFrame(
{
"foo": [1, None, 3, None],
"bar": [1, 2, None, 4],
}
)
df.sql("""
SELECT foo, bar, COALESCE(foo, bar) AS baz FROM self
""")
# shape: (4, 3)
# ┌──────┬──────┬─────┐
# │ foo ┆ bar ┆ baz │
# │ --- ┆ --- ┆ --- │
# │ i64 ┆ i64 ┆ i64 │
# ╞══════╪══════╪═════╡
# │ 1 ┆ 1 ┆ 1 │
# │ null ┆ 2 ┆ 2 │
# │ 3 ┆ null ┆ 3 │
# │ null ┆ 4 ┆ 4 │
# └──────┴──────┴─────┘
最大值#
返回表达式列表中的最大值。
示例:
df = pl.DataFrame(
{
"foo": [100, 200, 300, 400],
"bar": [20, 10, 30, 40]
}
)
df.sql("""
SELECT GREATEST(foo, bar) AS baz FROM self
""")
# shape: (4, 1)
# ┌─────┐
# │ baz │
# │ --- │
# │ i64 │
# ╞═════╡
# │ 100 │
# │ 200 │
# │ 300 │
# │ 400 │
# └─────┘
IF#
如果作为第一个参数提供的布尔条件评估为真,则返回expr1,否则返回expr2。
示例:
df = pl.DataFrame(
{
"foo": [100, 200, 300, 400],
"bar": [10, 20, 30, 40]
}
)
df.sql("""
SELECT IF(foo < 250, 111, 999) AS baz FROM self
""")
# shape: (4, 1)
# ┌─────┐
# │ baz │
# │ --- │
# │ i32 │
# ╞═════╡
# │ 111 │
# │ 111 │
# │ 999 │
# │ 999 │
# └─────┘
IFNULL#
如果表达式的值为NULL,则返回一个替代值。
示例:
df = pl.DataFrame(
{
"foo": ["a", None, None, "d"],
"bar": [1, 2, 3, 4],
}
)
df.sql("""
SELECT IFNULL(foo, 'n/a') AS baz FROM self
""")
# shape: (4, 1)
# ┌─────┐
# │ baz │
# │ --- │
# │ str │
# ╞═════╡
# │ a │
# │ n/a │
# │ n/a │
# │ d │
# └─────┘
最小值#
返回表达式列表中的最小值。
示例:
df = pl.DataFrame(
{
"foo": [100, 200, 300, 400],
"bar": [20, 10, 30, 40]
}
)
df.sql("""
SELECT LEAST(foo, bar) AS baz FROM self
""")
# shape: (4, 1)
# ┌─────┐
# │ baz │
# │ --- │
# │ i64 │
# ╞═════╡
# │ 20 │
# │ 10 │
# │ 30 │
# │ 40 │
# └─────┘
NULLIF#
如果两个表达式相等,则返回NULL,否则返回第一个表达式。
示例:
df = pl.DataFrame(
{
"foo": [100, 200, 300, 400],
"bar": [20, 10, 30, 40]
}
)
df.sql("""
SELECT NULLIF(foo, bar) AS baz FROM self
""")
# shape: (4, 1)
# ┌─────┐
# │ baz │
# │ --- │
# │ i64 │
# ╞═════╡
# │ 100 │
# │ 200 │
# │ 300 │
# │ 400 │
# └─────┘