Scalar
Scalar(arg)
Methods
Name | Description |
---|---|
as_scalar | Inform ibis that the expression should be treated as a scalar. |
as_table | Promote the scalar expression to a table. |
as_scalar
as_scalar()
Inform ibis that the expression should be treated as a scalar.
If the expression is a literal, it will be returned as is. If it depends on a table, it will be turned to a scalar subquery.
Returns
Name | Type | Description |
---|---|---|
Scalar | A scalar subquery or a literal |
Examples
>>> import ibis
>>> ibis.options.interactive = True
>>> t = ibis.examples.penguins.fetch()
>>> max_gentoo_weight = t.filter(t.species == "Gentoo").body_mass_g.max()
>>> light_penguins = t.filter(t.body_mass_g < max_gentoo_weight / 2)
>>> light_penguins.species.value_counts().order_by("species")
as_table
as_table()
Promote the scalar expression to a table.
Returns
Name | Type | Description |
---|---|---|
Table | A table expression |
Examples
Promote an aggregation to a table
>>> import ibis
>>> import ibis.expr.types as ir
>>> t = ibis.table(dict(a="str"), name="t")
>>> expr = t.a.length().sum().name("len").as_table()
>>> isinstance(expr, ir.Table)
Promote a literal value to a table
>>> import ibis.expr.types as ir
>>> lit = ibis.literal(1).name("a").as_table()
>>> isinstance(lit, ir.Table)