polars_plan/dsl/function_expr/
cat.rsuse super::*;
use crate::map;
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
#[derive(Clone, PartialEq, Debug, Eq, Hash)]
pub enum CategoricalFunction {
GetCategories,
}
impl CategoricalFunction {
pub(super) fn get_field(&self, mapper: FieldsMapper) -> PolarsResult<Field> {
use CategoricalFunction::*;
match self {
GetCategories => mapper.with_dtype(DataType::String),
}
}
}
impl Display for CategoricalFunction {
fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
use CategoricalFunction::*;
let s = match self {
GetCategories => "get_categories",
};
write!(f, "cat.{s}")
}
}
impl From<CategoricalFunction> for SpecialEq<Arc<dyn ColumnsUdf>> {
fn from(func: CategoricalFunction) -> Self {
use CategoricalFunction::*;
match func {
GetCategories => map!(get_categories),
}
}
}
impl From<CategoricalFunction> for FunctionExpr {
fn from(func: CategoricalFunction) -> Self {
FunctionExpr::Categorical(func)
}
}
fn get_categories(s: &Column) -> PolarsResult<Column> {
let ca = s.categorical()?;
let rev_map = ca.get_rev_map();
let arr = rev_map.get_categories().clone().boxed();
Series::try_from((ca.name().clone(), arr)).map(Column::from)
}