pub type Int8DictionaryArray = DictionaryArray<Int8Type>;
Expand description
A DictionaryArray
indexed by i8
§Example: Using collect
let array: Int8DictionaryArray = vec!["a", "a", "b", "c"].into_iter().collect();
let values: Arc<dyn Array> = Arc::new(StringArray::from(vec!["a", "b", "c"]));
assert_eq!(array.keys(), &Int8Array::from(vec![0, 0, 1, 2]));
assert_eq!(array.values(), &values);
See DictionaryArray
for more information and examples
Aliased Type§
struct Int8DictionaryArray { /* private fields */ }
Implementations
Source§impl<K: ArrowDictionaryKeyType> DictionaryArray<K>
impl<K: ArrowDictionaryKeyType> DictionaryArray<K>
Sourcepub fn new(keys: PrimitiveArray<K>, values: ArrayRef) -> Self
pub fn new(keys: PrimitiveArray<K>, values: ArrayRef) -> Self
Attempt to create a new DictionaryArray with a specified keys (indexes into the dictionary) and values (dictionary) array.
§Panics
Panics if Self::try_new
returns an error
Sourcepub fn try_new(
keys: PrimitiveArray<K>,
values: ArrayRef,
) -> Result<Self, ArrowError>
pub fn try_new( keys: PrimitiveArray<K>, values: ArrayRef, ) -> Result<Self, ArrowError>
Attempt to create a new DictionaryArray with a specified keys (indexes into the dictionary) and values (dictionary) array.
§Errors
Returns an error if any keys[i] >= values.len() || keys[i] < 0
Sourcepub fn new_scalar<T: Array + 'static>(value: Scalar<T>) -> Scalar<Self>
pub fn new_scalar<T: Array + 'static>(value: Scalar<T>) -> Scalar<Self>
Create a new Scalar
from value
Sourcepub unsafe fn new_unchecked(keys: PrimitiveArray<K>, values: ArrayRef) -> Self
pub unsafe fn new_unchecked(keys: PrimitiveArray<K>, values: ArrayRef) -> Self
Create a new DictionaryArray
without performing validation
§Safety
Safe provided Self::try_new
would not return an error
Sourcepub fn into_parts(self) -> (PrimitiveArray<K>, ArrayRef)
pub fn into_parts(self) -> (PrimitiveArray<K>, ArrayRef)
Deconstruct this array into its constituent parts
Sourcepub fn keys(&self) -> &PrimitiveArray<K>
pub fn keys(&self) -> &PrimitiveArray<K>
Return an array view of the keys of this dictionary as a PrimitiveArray.
Sourcepub fn lookup_key(&self, value: &str) -> Option<K::Native>
pub fn lookup_key(&self, value: &str) -> Option<K::Native>
If value
is present in values
(aka the dictionary),
returns the corresponding key (index into the values
array). Otherwise returns None
.
Panics if values
is not a StringArray
.
Sourcepub fn value_type(&self) -> DataType
pub fn value_type(&self) -> DataType
Returns a clone of the value type of this list.
Sourcepub fn is_ordered(&self) -> bool
pub fn is_ordered(&self) -> bool
Currently exists for compatibility purposes with Arrow IPC.
Sourcepub fn keys_iter(&self) -> impl Iterator<Item = Option<usize>> + '_
pub fn keys_iter(&self) -> impl Iterator<Item = Option<usize>> + '_
Return an iterator over the keys (indexes into the dictionary)
Sourcepub fn key(&self, i: usize) -> Option<usize>
pub fn key(&self, i: usize) -> Option<usize>
Return the value of keys
(the dictionary key) at index i
,
cast to usize
, None
if the value at i
is NULL
.
Sourcepub fn slice(&self, offset: usize, length: usize) -> Self
pub fn slice(&self, offset: usize, length: usize) -> Self
Returns a zero-copy slice of this array with the indicated offset and length.
Sourcepub fn downcast_dict<V: 'static>(
&self,
) -> Option<TypedDictionaryArray<'_, K, V>>
pub fn downcast_dict<V: 'static>( &self, ) -> Option<TypedDictionaryArray<'_, K, V>>
Downcast this dictionary to a TypedDictionaryArray
use arrow_array::{Array, ArrayAccessor, DictionaryArray, StringArray, types::Int32Type};
let orig = [Some("a"), Some("b"), None];
let dictionary = DictionaryArray::<Int32Type>::from_iter(orig);
let typed = dictionary.downcast_dict::<StringArray>().unwrap();
assert_eq!(typed.value(0), "a");
assert_eq!(typed.value(1), "b");
assert!(typed.is_null(2));
Sourcepub fn with_values(&self, values: ArrayRef) -> Self
pub fn with_values(&self, values: ArrayRef) -> Self
Returns a new dictionary with the same keys as the current instance but with a different set of dictionary values
This can be used to perform an operation on the values of a dictionary
§Panics
Panics if values
has a length less than the current values
// Construct a Dict(Int32, Int8)
let mut builder = PrimitiveDictionaryBuilder::<Int32Type, Int8Type>::with_capacity(2, 200);
for i in 0..100 {
builder.append(i % 2).unwrap();
}
let dictionary = builder.finish();
// Perform a widening cast of dictionary values
let typed_dictionary = dictionary.downcast_dict::<Int8Array>().unwrap();
let values: Int64Array = typed_dictionary.values().unary(|x| x as i64);
// Create a Dict(Int32,
let new = dictionary.with_values(Arc::new(values));
// Verify values are as expected
let new_typed = new.downcast_dict::<Int64Array>().unwrap();
for i in 0..100 {
assert_eq!(new_typed.value(i), (i % 2) as i64)
}
Sourcepub fn into_primitive_dict_builder<V>(
self,
) -> Result<PrimitiveDictionaryBuilder<K, V>, Self>where
V: ArrowPrimitiveType,
pub fn into_primitive_dict_builder<V>(
self,
) -> Result<PrimitiveDictionaryBuilder<K, V>, Self>where
V: ArrowPrimitiveType,
Returns PrimitiveDictionaryBuilder
of this dictionary array for mutating
its keys and values if the underlying data buffer is not shared by others.
Sourcepub fn unary_mut<F, V>(
self,
op: F,
) -> Result<DictionaryArray<K>, DictionaryArray<K>>
pub fn unary_mut<F, V>( self, op: F, ) -> Result<DictionaryArray<K>, DictionaryArray<K>>
Applies an unary and infallible function to a mutable dictionary array. Mutable dictionary array means that the buffers are not shared with other arrays. As a result, this mutates the buffers directly without allocating new buffers.
§Implementation
This will apply the function for all dictionary values, including those on null slots. This implies that the operation must be infallible for any value of the corresponding type or this function may panic.
§Example
let values = Int32Array::from(vec![Some(10), Some(20), None]);
let keys = Int8Array::from_iter_values([0, 0, 1, 2]);
let dictionary = DictionaryArray::<Int8Type>::try_new(keys, Arc::new(values)).unwrap();
let c = dictionary.unary_mut::<_, Int32Type>(|x| x + 1).unwrap();
let typed = c.downcast_dict::<Int32Array>().unwrap();
assert_eq!(typed.value(0), 11);
assert_eq!(typed.value(1), 11);
assert_eq!(typed.value(2), 21);
Sourcepub fn occupancy(&self) -> BooleanBuffer
pub fn occupancy(&self) -> BooleanBuffer
Computes an occupancy mask for this dictionary’s values
For each value in Self::values
the corresponding bit will be set in the
returned mask if it is referenced by a key in this DictionaryArray
Trait Implementations
Source§impl<K: ArrowDictionaryKeyType> AnyDictionaryArray for DictionaryArray<K>
impl<K: ArrowDictionaryKeyType> AnyDictionaryArray for DictionaryArray<K>
Source§impl<T: ArrowDictionaryKeyType> Array for DictionaryArray<T>
impl<T: ArrowDictionaryKeyType> Array for DictionaryArray<T>
Source§fn slice(&self, offset: usize, length: usize) -> ArrayRef
fn slice(&self, offset: usize, length: usize) -> ArrayRef
Source§fn offset(&self) -> usize
fn offset(&self) -> usize
0
. Read moreSource§fn nulls(&self) -> Option<&NullBuffer>
fn nulls(&self) -> Option<&NullBuffer>
Source§fn logical_nulls(&self) -> Option<NullBuffer>
fn logical_nulls(&self) -> Option<NullBuffer>
NullBuffer
that represents the logical
null values of this array, if any. Read moreSource§fn is_nullable(&self) -> bool
fn is_nullable(&self) -> bool
false
if the array is guaranteed to not contain any logical nulls Read moreSource§fn get_buffer_memory_size(&self) -> usize
fn get_buffer_memory_size(&self) -> usize
Source§fn get_array_memory_size(&self) -> usize
fn get_array_memory_size(&self) -> usize
get_buffer_memory_size()
and
includes the overhead of the data structures that contain the pointers to the various buffers.Source§fn null_count(&self) -> usize
fn null_count(&self) -> usize
Source§fn logical_null_count(&self) -> usize
fn logical_null_count(&self) -> usize
Source§impl<K: ArrowDictionaryKeyType> Clone for DictionaryArray<K>
impl<K: ArrowDictionaryKeyType> Clone for DictionaryArray<K>
Source§impl<T: ArrowDictionaryKeyType> Debug for DictionaryArray<T>
impl<T: ArrowDictionaryKeyType> Debug for DictionaryArray<T>
Source§impl<T: ArrowDictionaryKeyType> From<ArrayData> for DictionaryArray<T>
impl<T: ArrowDictionaryKeyType> From<ArrayData> for DictionaryArray<T>
Constructs a DictionaryArray
from an array data reference.
Source§impl<'a, T: ArrowDictionaryKeyType> FromIterator<&'a str> for DictionaryArray<T>
impl<'a, T: ArrowDictionaryKeyType> FromIterator<&'a str> for DictionaryArray<T>
Constructs a DictionaryArray
from an iterator of strings.
§Example:
use arrow_array::{DictionaryArray, PrimitiveArray, StringArray, types::Int8Type};
let test = vec!["a", "a", "b", "c"];
let array: DictionaryArray<Int8Type> = test.into_iter().collect();
assert_eq!(
"DictionaryArray {keys: PrimitiveArray<Int8>\n[\n 0,\n 0,\n 1,\n 2,\n] values: StringArray\n[\n \"a\",\n \"b\",\n \"c\",\n]}\n",
format!("{:?}", array)
);
Source§impl<'a, T: ArrowDictionaryKeyType> FromIterator<Option<&'a str>> for DictionaryArray<T>
impl<'a, T: ArrowDictionaryKeyType> FromIterator<Option<&'a str>> for DictionaryArray<T>
Constructs a DictionaryArray
from an iterator of optional strings.
§Example:
use arrow_array::{DictionaryArray, PrimitiveArray, StringArray, types::Int8Type};
let test = vec!["a", "a", "b", "c"];
let array: DictionaryArray<Int8Type> = test
.iter()
.map(|&x| if x == "b" { None } else { Some(x) })
.collect();
assert_eq!(
"DictionaryArray {keys: PrimitiveArray<Int8>\n[\n 0,\n 0,\n null,\n 1,\n] values: StringArray\n[\n \"a\",\n \"c\",\n]}\n",
format!("{:?}", array)
);