Struct polars_arrow::array::ListArray
source · pub struct ListArray<O: Offset> { /* private fields */ }Expand description
An Array semantically equivalent to Vec<Option<Vec<Option<T>>>> with Arrow’s in-memory.
Implementations§
source§impl<'a, O: Offset> ListArray<O>
impl<'a, O: Offset> ListArray<O>
sourcepub fn iter(
&'a self
) -> ZipValidity<Box<dyn Array>, ListValuesIter<'a, O>, BitmapIter<'a>> ⓘ
pub fn iter( &'a self ) -> ZipValidity<Box<dyn Array>, ListValuesIter<'a, O>, BitmapIter<'a>> ⓘ
Returns an iterator of Option<Box<dyn Array>>
sourcepub fn values_iter(&'a self) -> ListValuesIter<'a, O>
pub fn values_iter(&'a self) -> ListValuesIter<'a, O>
Returns an iterator of Box<dyn Array>
source§impl<O: Offset> ListArray<O>
impl<O: Offset> ListArray<O>
sourcepub fn try_new(
data_type: DataType,
offsets: OffsetsBuffer<O>,
values: Box<dyn Array>,
validity: Option<Bitmap>
) -> PolarsResult<Self>
pub fn try_new( data_type: DataType, offsets: OffsetsBuffer<O>, values: Box<dyn Array>, validity: Option<Bitmap> ) -> PolarsResult<Self>
Creates a new ListArray.
Errors
This function returns an error iff:
- The last offset is not equal to the values’ length.
- the validity’s length is not equal to
offsets.len(). - The
data_type’scrate::datatypes::PhysicalTypeis not equal to eithercrate::datatypes::PhysicalType::Listorcrate::datatypes::PhysicalType::LargeList. - The
data_type’s inner field’s data type is not equal tovalues.data_type.
Implementation
This function is O(1)
sourcepub fn new(
data_type: DataType,
offsets: OffsetsBuffer<O>,
values: Box<dyn Array>,
validity: Option<Bitmap>
) -> Self
pub fn new( data_type: DataType, offsets: OffsetsBuffer<O>, values: Box<dyn Array>, validity: Option<Bitmap> ) -> Self
Creates a new ListArray.
Panics
This function panics iff:
- The last offset is not equal to the values’ length.
- the validity’s length is not equal to
offsets.len(). - The
data_type’scrate::datatypes::PhysicalTypeis not equal to eithercrate::datatypes::PhysicalType::Listorcrate::datatypes::PhysicalType::LargeList. - The
data_type’s inner field’s data type is not equal tovalues.data_type.
Implementation
This function is O(1)
source§impl<O: Offset> ListArray<O>
impl<O: Offset> ListArray<O>
sourcepub unsafe fn slice_unchecked(&mut self, offset: usize, length: usize)
pub unsafe fn slice_unchecked(&mut self, offset: usize, length: usize)
sourcepub fn sliced(self, offset: usize, length: usize) -> Self
pub fn sliced(self, offset: usize, length: usize) -> Self
Returns this array sliced.
Implementation
This function is O(1).
Panics
iff offset + length > self.len().
sourcepub unsafe fn sliced_unchecked(self, offset: usize, length: usize) -> Self
pub unsafe fn sliced_unchecked(self, offset: usize, length: usize) -> Self
Returns this array sliced.
Implementation
This function is O(1).
Safety
The caller must ensure that offset + length <= self.len().
sourcepub fn with_validity(self, validity: Option<Bitmap>) -> Self
pub fn with_validity(self, validity: Option<Bitmap>) -> Self
sourcepub fn set_validity(&mut self, validity: Option<Bitmap>)
pub fn set_validity(&mut self, validity: Option<Bitmap>)
sourcepub fn boxed(self) -> Box<dyn Array>
pub fn boxed(self) -> Box<dyn Array>
Boxes this array into a Box<dyn Array>.
sourcepub fn arced(self) -> Arc<dyn Array>
pub fn arced(self) -> Arc<dyn Array>
Arcs this array into a std::sync::Arc<dyn Array>.
source§impl<O: Offset> ListArray<O>
impl<O: Offset> ListArray<O>
source§impl<O: Offset> ListArray<O>
impl<O: Offset> ListArray<O>
sourcepub fn default_datatype(data_type: DataType) -> DataType
pub fn default_datatype(data_type: DataType) -> DataType
Returns a default DataType: inner field is named “item” and is nullable
sourcepub fn get_child_field(data_type: &DataType) -> &Field
pub fn get_child_field(data_type: &DataType) -> &Field
sourcepub fn try_get_child(data_type: &DataType) -> PolarsResult<&Field>
pub fn try_get_child(data_type: &DataType) -> PolarsResult<&Field>
Trait Implementations§
source§impl<O: Offset> Array for ListArray<O>
impl<O: Offset> Array for ListArray<O>
source§fn as_any(&self) -> &dyn Any
fn as_any(&self) -> &dyn Any
Converts itself to a reference of
Any, which enables downcasting to concrete types.source§fn as_any_mut(&mut self) -> &mut dyn Any
fn as_any_mut(&mut self) -> &mut dyn Any
Converts itself to a mutable reference of
Any, which enables mutable downcasting to concrete types.source§fn len(&self) -> usize
fn len(&self) -> usize
The length of the
Array. Every array has a length corresponding to the number of
elements (slots).source§fn data_type(&self) -> &DataType
fn data_type(&self) -> &DataType
The
DataType of the Array. In combination with Array::as_any, this can be
used to downcast trait objects (dyn Array) to concrete arrays.source§unsafe fn slice_unchecked(&mut self, offset: usize, length: usize)
unsafe fn slice_unchecked(&mut self, offset: usize, length: usize)
source§unsafe fn is_null_unchecked(&self, i: usize) -> bool
unsafe fn is_null_unchecked(&self, i: usize) -> bool
Returns whether slot
i is null. Read moresource§impl<O: Offset> Arrow2Arrow for ListArray<O>
impl<O: Offset> Arrow2Arrow for ListArray<O>
source§impl<'a, O: Offset> From<GrowableList<'a, O>> for ListArray<O>
impl<'a, O: Offset> From<GrowableList<'a, O>> for ListArray<O>
source§fn from(val: GrowableList<'a, O>) -> Self
fn from(val: GrowableList<'a, O>) -> Self
Converts to this type from the input type.
source§impl<O: Offset, M: MutableArray> From<MutableListArray<O, M>> for ListArray<O>
impl<O: Offset, M: MutableArray> From<MutableListArray<O, M>> for ListArray<O>
source§fn from(other: MutableListArray<O, M>) -> Self
fn from(other: MutableListArray<O, M>) -> Self
Converts to this type from the input type.
source§impl<'a, O: Offset> IntoIterator for &'a ListArray<O>
impl<'a, O: Offset> IntoIterator for &'a ListArray<O>
§type IntoIter = ZipValidity<Box<dyn Array>, ArrayValuesIter<'a, ListArray<O>>, BitmapIter<'a>>
type IntoIter = ZipValidity<Box<dyn Array>, ArrayValuesIter<'a, ListArray<O>>, BitmapIter<'a>>
Which kind of iterator are we turning this into?
source§impl ListFromIter for ListArray<i64>
impl ListFromIter for ListArray<i64>
source§unsafe fn from_iter_primitive_trusted_len<T, P, I>(
iter: I,
data_type: DataType
) -> ListArray<i64>where
T: NativeType,
P: IntoIterator<Item = Option<T>>,
I: IntoIterator<Item = Option<P>>,
unsafe fn from_iter_primitive_trusted_len<T, P, I>( iter: I, data_type: DataType ) -> ListArray<i64>where T: NativeType, P: IntoIterator<Item = Option<T>>, I: IntoIterator<Item = Option<P>>,
Create a list-array from an iterator.
Used in group_by agg-list Read more
source§unsafe fn from_iter_bool_trusted_len<I, P>(iter: I) -> ListArray<i64>where
I: IntoIterator<Item = Option<P>>,
P: IntoIterator<Item = Option<bool>>,
unsafe fn from_iter_bool_trusted_len<I, P>(iter: I) -> ListArray<i64>where I: IntoIterator<Item = Option<P>>, P: IntoIterator<Item = Option<bool>>,
Create a list-array from an iterator.
Used in group_by agg-list Read more
source§unsafe fn from_iter_utf8_trusted_len<I, P, Ref>(
iter: I,
n_elements: usize
) -> ListArray<i64>where
I: IntoIterator<Item = Option<P>>,
P: IntoIterator<Item = Option<Ref>>,
Ref: AsRef<str>,
unsafe fn from_iter_utf8_trusted_len<I, P, Ref>( iter: I, n_elements: usize ) -> ListArray<i64>where I: IntoIterator<Item = Option<P>>, P: IntoIterator<Item = Option<Ref>>, Ref: AsRef<str>,
Create a list-array from an iterator.
Used in group_by agg-list Read more
source§unsafe fn from_iter_binary_trusted_len<I, P, Ref>(
iter: I,
n_elements: usize
) -> ListArray<i64>where
I: IntoIterator<Item = Option<P>>,
P: IntoIterator<Item = Option<Ref>>,
Ref: AsRef<[u8]>,
unsafe fn from_iter_binary_trusted_len<I, P, Ref>( iter: I, n_elements: usize ) -> ListArray<i64>where I: IntoIterator<Item = Option<P>>, P: IntoIterator<Item = Option<Ref>>, Ref: AsRef<[u8]>,
Create a list-array from an iterator.
Used in group_by agg-list Read more
source§impl<O: Offset> PartialEq<&(dyn Array + 'static)> for ListArray<O>
impl<O: Offset> PartialEq<&(dyn Array + 'static)> for ListArray<O>
source§impl<O: Offset> PartialEq for ListArray<O>
impl<O: Offset> PartialEq for ListArray<O>
source§impl ValueSize for ListArray<i64>
impl ValueSize for ListArray<i64>
source§fn get_values_size(&self) -> usize
fn get_values_size(&self) -> usize
Useful for a Utf8 or a List to get underlying value size.
During a rechunk this is handy
impl ArrowArray for ListArray<i64>
Auto Trait Implementations§
impl<O> !RefUnwindSafe for ListArray<O>
impl<O> Send for ListArray<O>
impl<O> Sync for ListArray<O>
impl<O> Unpin for ListArray<O>
impl<O> !UnwindSafe for ListArray<O>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more