polars_core::series

Trait SeriesTrait

Source
pub trait SeriesTrait:
    Send
    + Sync
    + PrivateSeries
    + PrivateSeriesNumeric {
Show 65 methods // Required methods fn rename(&mut self, name: PlSmallStr); fn chunk_lengths(&self) -> ChunkLenIter<'_>; fn name(&self) -> &PlSmallStr; fn chunks(&self) -> &Vec<ArrayRef>; unsafe fn chunks_mut(&mut self) -> &mut Vec<ArrayRef>; fn slice(&self, _offset: i64, _length: usize) -> Series; fn split_at(&self, _offset: i64) -> (Series, Series); fn append(&mut self, other: &Series) -> PolarsResult<()>; fn append_owned(&mut self, other: Series) -> PolarsResult<()>; fn filter(&self, _filter: &BooleanChunked) -> PolarsResult<Series>; fn take(&self, _indices: &IdxCa) -> PolarsResult<Series>; unsafe fn take_unchecked(&self, _idx: &IdxCa) -> Series; fn take_slice(&self, _indices: &[IdxSize]) -> PolarsResult<Series>; unsafe fn take_slice_unchecked(&self, _idx: &[IdxSize]) -> Series; fn len(&self) -> usize; fn rechunk(&self) -> Series; fn new_from_index(&self, _index: usize, _length: usize) -> Series; fn cast( &self, _dtype: &DataType, options: CastOptions, ) -> PolarsResult<Series>; unsafe fn get_unchecked(&self, _index: usize) -> AnyValue<'_>; fn null_count(&self) -> usize; fn has_nulls(&self) -> bool; fn is_null(&self) -> BooleanChunked; fn is_not_null(&self) -> BooleanChunked; fn reverse(&self) -> Series; fn shift(&self, _periods: i64) -> Series; fn clone_inner(&self) -> Arc<dyn SeriesTrait>; fn as_any(&self) -> &dyn Any; fn as_any_mut(&mut self) -> &mut dyn Any; fn as_arc_any(self: Arc<Self>) -> Arc<dyn Any + Send + Sync>; // Provided methods fn field(&self) -> Cow<'_, Field> { ... } fn dtype(&self) -> &DataType { ... } fn n_chunks(&self) -> usize { ... } fn shrink_to_fit(&mut self) { ... } fn limit(&self, num_elements: usize) -> Series { ... } fn is_empty(&self) -> bool { ... } fn rechunk_validity(&self) -> Option<Bitmap> { ... } fn drop_nulls(&self) -> Series { ... } fn _sum_as_f64(&self) -> f64 { ... } fn mean(&self) -> Option<f64> { ... } fn std(&self, _ddof: u8) -> Option<f64> { ... } fn var(&self, _ddof: u8) -> Option<f64> { ... } fn median(&self) -> Option<f64> { ... } fn get(&self, index: usize) -> PolarsResult<AnyValue<'_>> { ... } fn sort_with(&self, _options: SortOptions) -> PolarsResult<Series> { ... } fn arg_sort(&self, options: SortOptions) -> IdxCa { ... } fn unique(&self) -> PolarsResult<Series> { ... } fn n_unique(&self) -> PolarsResult<usize> { ... } fn arg_unique(&self) -> PolarsResult<IdxCa> { ... } fn as_single_ptr(&mut self) -> PolarsResult<usize> { ... } fn sum_reduce(&self) -> PolarsResult<Scalar> { ... } fn max_reduce(&self) -> PolarsResult<Scalar> { ... } fn min_reduce(&self) -> PolarsResult<Scalar> { ... } fn median_reduce(&self) -> PolarsResult<Scalar> { ... } fn var_reduce(&self, _ddof: u8) -> PolarsResult<Scalar> { ... } fn std_reduce(&self, _ddof: u8) -> PolarsResult<Scalar> { ... } fn quantile_reduce( &self, _quantile: f64, _method: QuantileMethod, ) -> PolarsResult<Scalar> { ... } fn and_reduce(&self) -> PolarsResult<Scalar> { ... } fn or_reduce(&self) -> PolarsResult<Scalar> { ... } fn xor_reduce(&self) -> PolarsResult<Scalar> { ... } fn first(&self) -> Scalar { ... } fn last(&self) -> Scalar { ... } fn get_object(&self, _index: usize) -> Option<&dyn PolarsObjectSafe> { ... } unsafe fn get_object_chunked_unchecked( &self, _chunk: usize, _index: usize, ) -> Option<&dyn PolarsObjectSafe> { ... } fn checked_div(&self, _rhs: &Series) -> PolarsResult<Series> { ... } fn rolling_map( &self, _f: &dyn Fn(&Series) -> Series, _options: RollingOptionsFixedWindow, ) -> PolarsResult<Series> { ... }
}

Required Methods§

Source

fn rename(&mut self, name: PlSmallStr)

Rename the Series.

Source

fn chunk_lengths(&self) -> ChunkLenIter<'_>

Get the lengths of the underlying chunks

Source

fn name(&self) -> &PlSmallStr

Name of series.

Source

fn chunks(&self) -> &Vec<ArrayRef>

Underlying chunks.

Source

unsafe fn chunks_mut(&mut self) -> &mut Vec<ArrayRef>

Underlying chunks.

§Safety

The caller must ensure the length and the data types of ArrayRef does not change.

Source

fn slice(&self, _offset: i64, _length: usize) -> Series

Get a zero copy view of the data.

When offset is negative the offset is counted from the end of the array

Source

fn split_at(&self, _offset: i64) -> (Series, Series)

Get a zero copy view of the data.

When offset is negative the offset is counted from the end of the array

Source

fn append(&mut self, other: &Series) -> PolarsResult<()>

Source

fn append_owned(&mut self, other: Series) -> PolarsResult<()>

Source

fn filter(&self, _filter: &BooleanChunked) -> PolarsResult<Series>

Filter by boolean mask. This operation clones data.

Source

fn take(&self, _indices: &IdxCa) -> PolarsResult<Series>

Take from self at the indexes given by idx.

Null values in idx because null values in the output array.

This operation is clone.

Source

unsafe fn take_unchecked(&self, _idx: &IdxCa) -> Series

Take from self at the indexes given by idx.

Null values in idx because null values in the output array.

§Safety

This doesn’t check any bounds.

Source

fn take_slice(&self, _indices: &[IdxSize]) -> PolarsResult<Series>

Take from self at the indexes given by idx.

This operation is clone.

Source

unsafe fn take_slice_unchecked(&self, _idx: &[IdxSize]) -> Series

Take from self at the indexes given by idx.

§Safety

This doesn’t check any bounds.

Source

fn len(&self) -> usize

Get length of series.

Source

fn rechunk(&self) -> Series

Aggregate all chunks to a contiguous array of memory.

Source

fn new_from_index(&self, _index: usize, _length: usize) -> Series

Create a new Series filled with values from the given index.

§Example
use polars_core::prelude::*;
let s = Series::new("a".into(), [0i32, 1, 8]);
let s2 = s.new_from_index(2, 4);
assert_eq!(Vec::from(s2.i32().unwrap()), &[Some(8), Some(8), Some(8), Some(8)])
Source

fn cast(&self, _dtype: &DataType, options: CastOptions) -> PolarsResult<Series>

Source

unsafe fn get_unchecked(&self, _index: usize) -> AnyValue<'_>

Get a single value by index. Don’t use this operation for loops as a runtime cast is needed for every iteration.

This may refer to physical types

§Safety

Does not do any bounds checking

Source

fn null_count(&self) -> usize

Count the null values.

Source

fn has_nulls(&self) -> bool

Return if any the chunks in this ChunkedArray have nulls.

Source

fn is_null(&self) -> BooleanChunked

Get a mask of the null values.

Source

fn is_not_null(&self) -> BooleanChunked

Get a mask of the non-null values.

Source

fn reverse(&self) -> Series

return a Series in reversed order

Source

fn shift(&self, _periods: i64) -> Series

Shift the values by a given period and fill the parts that will be empty due to this operation with Nones.

NOTE: If you want to fill the Nones with a value use the shift operation on ChunkedArray<T>.

§Example
fn example() -> PolarsResult<()> {
    let s = Series::new("series".into(), &[1, 2, 3]);

    let shifted = s.shift(1);
    assert_eq!(Vec::from(shifted.i32()?), &[None, Some(1), Some(2)]);

    let shifted = s.shift(-1);
    assert_eq!(Vec::from(shifted.i32()?), &[Some(2), Some(3), None]);

    let shifted = s.shift(2);
    assert_eq!(Vec::from(shifted.i32()?), &[None, None, Some(1)]);

    Ok(())
}
example();
Source

fn clone_inner(&self) -> Arc<dyn SeriesTrait>

Clone inner ChunkedArray and wrap in a new Arc

Source

fn as_any(&self) -> &dyn Any

Get a hold of the ChunkedArray, Logical or NullChunked as an Any trait reference.

Source

fn as_any_mut(&mut self) -> &mut dyn Any

Get a hold of the ChunkedArray, Logical or NullChunked as an Any trait mutable reference.

Source

fn as_arc_any(self: Arc<Self>) -> Arc<dyn Any + Send + Sync>

Provided Methods§

Source

fn field(&self) -> Cow<'_, Field>

Get field (used in schema)

Source

fn dtype(&self) -> &DataType

Get datatype of series.

Source

fn n_chunks(&self) -> usize

Number of chunks in this Series

Source

fn shrink_to_fit(&mut self)

Shrink the capacity of this array to fit its length.

Source

fn limit(&self, num_elements: usize) -> Series

Take num_elements from the top as a zero copy view.

Source

fn is_empty(&self) -> bool

Check if Series is empty.

Source

fn rechunk_validity(&self) -> Option<Bitmap>

Source

fn drop_nulls(&self) -> Series

Drop all null values and return a new Series.

Source

fn _sum_as_f64(&self) -> f64

Returns the sum of the array as an f64.

Source

fn mean(&self) -> Option<f64>

Returns the mean value in the array Returns an option because the array is nullable.

Source

fn std(&self, _ddof: u8) -> Option<f64>

Returns the std value in the array Returns an option because the array is nullable.

Source

fn var(&self, _ddof: u8) -> Option<f64>

Returns the var value in the array Returns an option because the array is nullable.

Source

fn median(&self) -> Option<f64>

Returns the median value in the array Returns an option because the array is nullable.

Source

fn get(&self, index: usize) -> PolarsResult<AnyValue<'_>>

Get a single value by index. Don’t use this operation for loops as a runtime cast is needed for every iteration.

Source

fn sort_with(&self, _options: SortOptions) -> PolarsResult<Series>

Source

fn arg_sort(&self, options: SortOptions) -> IdxCa

Retrieve the indexes needed for a sort.

Source

fn unique(&self) -> PolarsResult<Series>

Get unique values in the Series.

Source

fn n_unique(&self) -> PolarsResult<usize>

Get unique values in the Series.

A null value also counts as a unique value.

Source

fn arg_unique(&self) -> PolarsResult<IdxCa>

Get first indexes of unique values.

Source

fn as_single_ptr(&mut self) -> PolarsResult<usize>

Rechunk and return a pointer to the start of the Series. Only implemented for numeric types

Source

fn sum_reduce(&self) -> PolarsResult<Scalar>

Get the sum of the Series as a new Scalar.

If the DataType is one of {Int8, UInt8, Int16, UInt16} the Series is first cast to Int64 to prevent overflow issues.

Source

fn max_reduce(&self) -> PolarsResult<Scalar>

Get the max of the Series as a new Series of length 1.

Source

fn min_reduce(&self) -> PolarsResult<Scalar>

Get the min of the Series as a new Series of length 1.

Source

fn median_reduce(&self) -> PolarsResult<Scalar>

Get the median of the Series as a new Series of length 1.

Source

fn var_reduce(&self, _ddof: u8) -> PolarsResult<Scalar>

Get the variance of the Series as a new Series of length 1.

Source

fn std_reduce(&self, _ddof: u8) -> PolarsResult<Scalar>

Get the standard deviation of the Series as a new Series of length 1.

Source

fn quantile_reduce( &self, _quantile: f64, _method: QuantileMethod, ) -> PolarsResult<Scalar>

Get the quantile of the ChunkedArray as a new Series of length 1.

Source

fn and_reduce(&self) -> PolarsResult<Scalar>

Get the bitwise AND of the Series as a new Series of length 1,

Source

fn or_reduce(&self) -> PolarsResult<Scalar>

Get the bitwise OR of the Series as a new Series of length 1,

Source

fn xor_reduce(&self) -> PolarsResult<Scalar>

Get the bitwise XOR of the Series as a new Series of length 1,

Source

fn first(&self) -> Scalar

Get the first element of the Series as a Scalar

If the Series is empty, a Scalar with a AnyValue::Null is returned.

Source

fn last(&self) -> Scalar

Get the last element of the Series as a Scalar

If the Series is empty, a Scalar with a AnyValue::Null is returned.

Source

fn get_object(&self, _index: usize) -> Option<&dyn PolarsObjectSafe>

Available on crate feature object only.

Get the value at this index as a downcastable Any trait ref.

Source

unsafe fn get_object_chunked_unchecked( &self, _chunk: usize, _index: usize, ) -> Option<&dyn PolarsObjectSafe>

Available on crate feature object only.

Get the value at this index as a downcastable Any trait ref.

§Safety

This function doesn’t do any bound checks.

Source

fn checked_div(&self, _rhs: &Series) -> PolarsResult<Series>

Available on crate feature checked_arithmetic only.
Source

fn rolling_map( &self, _f: &dyn Fn(&Series) -> Series, _options: RollingOptionsFixedWindow, ) -> PolarsResult<Series>

Available on crate feature rolling_window only.

Apply a custom function over a rolling/ moving window of the array. This has quite some dynamic dispatch, so prefer rolling_min, max, mean, sum over this.

Implementations§

Source§

impl dyn SeriesTrait + '_

Source

pub fn unpack<N>(&self) -> PolarsResult<&ChunkedArray<N>>
where N: 'static + PolarsDataType<IsLogical = FalseT>,

Trait Implementations§

Source§

impl<T> AsMut<ChunkedArray<T>> for dyn SeriesTrait + '_
where T: 'static + PolarsDataType<IsLogical = FalseT>,

Source§

fn as_mut(&mut self) -> &mut ChunkedArray<T>

Converts this type into a mutable reference of the (usually inferred) input type.
Source§

impl<T> AsRef<ChunkedArray<T>> for dyn SeriesTrait + '_
where T: 'static + PolarsDataType<IsLogical = FalseT>,

Source§

fn as_ref(&self) -> &ChunkedArray<T>

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<'a> AsRef<dyn SeriesTrait + 'a> for Series

Source§

fn as_ref(&self) -> &(dyn SeriesTrait + 'a)

Converts this type into a shared reference of the (usually inferred) input type.

Implementors§