pub struct StructuredArray { /* private fields */ }Expand description
A structured array: a flat byte buffer interpreted as n_records records,
each described by a StructuredDtype.
Implementations§
Source§impl StructuredArray
impl StructuredArray
Sourcepub fn new_empty(
n_records: usize,
field_specs: Vec<(String, String)>,
) -> PyResult<Self>
pub fn new_empty( n_records: usize, field_specs: Vec<(String, String)>, ) -> PyResult<Self>
Construct a zero-initialised structured array.
§Arguments
n_records– number of records to allocate.field_specs– list of(name, dtype_str)pairs defining the record layout.
Sourcepub fn get_field_f64(&self, field_name: &str) -> PyResult<Vec<f64>>
pub fn get_field_f64(&self, field_name: &str) -> PyResult<Vec<f64>>
Read all values for an f64 field as a Vec<f64>.
Returns PyKeyError if field_name is not found, or PyTypeError
if the field dtype is not "f64" / "float64".
Sourcepub fn set_field_f64(
&mut self,
field_name: &str,
values: Vec<f64>,
) -> PyResult<()>
pub fn set_field_f64( &mut self, field_name: &str, values: Vec<f64>, ) -> PyResult<()>
Write all values for an f64 field from a Vec<f64>.
Returns PyValueError if values.len() != n_records, PyKeyError if the
field is not found, or PyTypeError if the field dtype is not "f64" / "float64".
Sourcepub fn field_names(&self) -> Vec<String>
pub fn field_names(&self) -> Vec<String>
Return the names of all fields.
Trait Implementations§
impl DerefToPyAny for StructuredArray
impl ExtractPyClassWithClone for StructuredArray
Source§impl<'py> IntoPyObject<'py> for StructuredArray
impl<'py> IntoPyObject<'py> for StructuredArray
Source§type Target = StructuredArray
type Target = StructuredArray
The Python output type
Source§type Output = Bound<'py, <StructuredArray as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <StructuredArray as IntoPyObject<'py>>::Target>
The smart pointer type to use. Read more
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Performs the conversion.
Source§impl PyClass for StructuredArray
impl PyClass for StructuredArray
Source§impl PyClassImpl for StructuredArray
impl PyClassImpl for StructuredArray
Source§const MODULE: Option<&str> = ::core::option::Option::None
const MODULE: Option<&str> = ::core::option::Option::None
Module which the class will be associated with. Read more
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
#[pyclass(subclass)]
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
#[pyclass(extends=…)]
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
#[pyclass(mapping)]
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
#[pyclass(sequence)]
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
#[pyclass(immutable_type)]
Source§const RAW_DOC: &'static CStr = /// A structured array: a flat byte buffer interpreted as `n_records` records,
/// each described by a [`StructuredDtype`].
const RAW_DOC: &'static CStr = /// A structured array: a flat byte buffer interpreted as `n_records` records, /// each described by a [`StructuredDtype`].
Docstring for the class provided on the struct or enum. Read more
Source§const DOC: &'static CStr
const DOC: &'static CStr
Fully rendered class doc, including the
text_signature if a constructor is defined. Read moreSource§type Layout = <<StructuredArray as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<StructuredArray>
type Layout = <<StructuredArray as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<StructuredArray>
Description of how this class is laid out in memory
Source§type ThreadChecker = NoopThreadChecker
type ThreadChecker = NoopThreadChecker
This handles following two situations: Read more
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Immutable or mutable
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
The closest native ancestor. This is
PyAny by default, and when you declare
#[pyclass(extends=PyDict)], it’s PyDict.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
Source§fn dict_offset() -> Option<PyObjectOffset>
fn dict_offset() -> Option<PyObjectOffset>
Used to provide the dictoffset slot
(equivalent to tp_dictoffset)
Source§fn weaklist_offset() -> Option<PyObjectOffset>
fn weaklist_offset() -> Option<PyObjectOffset>
Used to provide the weaklistoffset slot
(equivalent to tp_weaklistoffset
Source§impl PyClassNewTextSignature for StructuredArray
impl PyClassNewTextSignature for StructuredArray
const TEXT_SIGNATURE: &'static str = "(n_records, field_specs)"
Source§impl PyMethods<StructuredArray> for PyClassImplCollector<StructuredArray>
impl PyMethods<StructuredArray> for PyClassImplCollector<StructuredArray>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for StructuredArray
impl PyTypeInfo for StructuredArray
Source§const NAME: &str = <Self as ::pyo3::PyClass>::NAME
const NAME: &str = <Self as ::pyo3::PyClass>::NAME
👎Deprecated since 0.28.0:
prefer using ::type_object(py).name() to get the correct runtime value
Class name.
Source§const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
👎Deprecated since 0.28.0:
prefer using ::type_object(py).module() to get the correct runtime value
Module name, if any.
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
Returns the PyTypeObject instance for this type.
Source§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
Returns the safe abstraction over the type object.
Auto Trait Implementations§
impl Freeze for StructuredArray
impl RefUnwindSafe for StructuredArray
impl Send for StructuredArray
impl Sync for StructuredArray
impl Unpin for StructuredArray
impl UnsafeUnpin for StructuredArray
impl UnwindSafe for StructuredArray
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
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
Source§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
Converts
self into an owned Python object, dropping type information.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
Source§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> Read<Exclusive, BecauseExclusive> for Twhere
T: ?Sized,
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.