pub struct Bound<'py, T>(/* private fields */);Expand description
A GIL-attached equivalent to Py<T>.
This type can be thought of as equivalent to the tuple (Py<T>, Python<'py>). By having the 'py
lifetime of the Python<'py> token, this ties the lifetime of the Bound<'py, T> smart pointer
to the lifetime of the GIL and allows PyO3 to call Python APIs at maximum efficiency.
To access the object in situations where the GIL is not held, convert it to Py<T>
using .unbind(). This includes situations where the GIL is temporarily
released, such as Python::detach’s closure.
See the guide for more detail.
Implementations§
Source§impl<'py, T> Bound<'py, T>where
T: PyClass,
impl<'py, T> Bound<'py, T>where
T: PyClass,
Sourcepub fn new(
py: Python<'py>,
value: impl Into<PyClassInitializer<T>>,
) -> Result<Bound<'py, T>, PyErr>
pub fn new( py: Python<'py>, value: impl Into<PyClassInitializer<T>>, ) -> Result<Bound<'py, T>, PyErr>
Creates a new instance Bound<T> of a #[pyclass] on the Python heap.
§Examples
use pyo3::prelude::*;
#[pyclass]
struct Foo {/* fields omitted */}
let foo: Py<Foo> = Python::attach(|py| -> PyResult<_> {
let foo: Bound<'_, Foo> = Bound::new(py, Foo {})?;
Ok(foo.into())
})?;Source§impl<'py, T> Bound<'py, T>
impl<'py, T> Bound<'py, T>
Sourcepub fn cast<U>(&self) -> Result<&Bound<'py, U>, DowncastError<'_, 'py>>where
U: PyTypeCheck,
pub fn cast<U>(&self) -> Result<&Bound<'py, U>, DowncastError<'_, 'py>>where
U: PyTypeCheck,
Cast this to a concrete Python type or pyclass.
Note that you can often avoid casting yourself by just specifying the desired type in function or method signatures. However, manual casting is sometimes necessary.
For extracting a Rust-only type, see extract.
This performs a runtime type check using the equivalent of Python’s
isinstance(self, U).
§Example: Casting to a specific Python object
use pyo3::prelude::*;
use pyo3::types::{PyDict, PyList};
Python::attach(|py| {
let dict = PyDict::new(py);
assert!(dict.is_instance_of::<PyAny>());
let any = dict.as_any();
assert!(any.cast::<PyDict>().is_ok());
assert!(any.cast::<PyList>().is_err());
});§Example: Getting a reference to a pyclass
This is useful if you want to mutate a Py<PyAny> that might actually be a pyclass.
use pyo3::prelude::*;
#[pyclass]
struct Class {
i: i32,
}
Python::attach(|py| {
let class = Bound::new(py, Class { i: 0 })?.into_any();
let class_bound: &Bound<'_, Class> = class.cast()?;
class_bound.borrow_mut().i += 1;
// Alternatively you can get a `PyRefMut` directly
let class_ref: PyRefMut<'_, Class> = class.extract()?;
assert_eq!(class_ref.i, 1);
Ok(())
})Sourcepub fn cast_into<U>(self) -> Result<Bound<'py, U>, DowncastIntoError<'py>>where
U: PyTypeCheck,
pub fn cast_into<U>(self) -> Result<Bound<'py, U>, DowncastIntoError<'py>>where
U: PyTypeCheck,
Like cast but takes ownership of self.
In case of an error, it is possible to retrieve self again via
DowncastIntoError::into_inner.
§Example
use pyo3::prelude::*;
use pyo3::types::{PyDict, PyList};
Python::attach(|py| {
let obj: Bound<'_, PyAny> = PyDict::new(py).into_any();
let obj: Bound<'_, PyAny> = match obj.cast_into::<PyList>() {
Ok(_) => panic!("obj should not be a list"),
Err(err) => err.into_inner(),
};
// obj is a dictionary
assert!(obj.cast_into::<PyDict>().is_ok());
})Sourcepub fn cast_exact<U>(&self) -> Result<&Bound<'py, U>, DowncastError<'_, 'py>>where
U: PyTypeInfo,
pub fn cast_exact<U>(&self) -> Result<&Bound<'py, U>, DowncastError<'_, 'py>>where
U: PyTypeInfo,
Cast this to a concrete Python type or pyclass (but not a subclass of it).
It is almost always better to use cast because it accounts for Python
subtyping. Use this method only when you do not want to allow subtypes.
The advantage of this method over cast is that it is faster. The
implementation of cast_exact uses the equivalent of the Python expression type(self) is U, whereas cast uses isinstance(self, U).
For extracting a Rust-only type, see extract.
§Example: Casting to a specific Python object but not a subtype
use pyo3::prelude::*;
use pyo3::types::{PyBool, PyInt};
Python::attach(|py| {
let b = PyBool::new(py, true);
assert!(b.is_instance_of::<PyBool>());
let any: &Bound<'_, PyAny> = b.as_any();
// `bool` is a subtype of `int`, so `cast` will accept a `bool` as an `int`
// but `cast_exact` will not.
assert!(any.cast::<PyInt>().is_ok());
assert!(any.cast_exact::<PyInt>().is_err());
assert!(any.cast_exact::<PyBool>().is_ok());
});Sourcepub fn cast_into_exact<U>(self) -> Result<Bound<'py, U>, DowncastIntoError<'py>>where
U: PyTypeInfo,
pub fn cast_into_exact<U>(self) -> Result<Bound<'py, U>, DowncastIntoError<'py>>where
U: PyTypeInfo,
Like cast_exact but takes ownership of self.
Sourcepub unsafe fn cast_unchecked<U>(&self) -> &Bound<'py, U>
pub unsafe fn cast_unchecked<U>(&self) -> &Bound<'py, U>
Converts this to a concrete Python type without checking validity.
§Safety
Callers must ensure that the type is valid or risk type confusion.
Sourcepub unsafe fn cast_into_unchecked<U>(self) -> Bound<'py, U>
pub unsafe fn cast_into_unchecked<U>(self) -> Bound<'py, U>
Like cast_unchecked but takes ownership of self.
§Safety
Callers must ensure that the type is valid or risk type confusion.
Source§impl<'py> Bound<'py, PyAny>
impl<'py> Bound<'py, PyAny>
Sourcepub unsafe fn from_owned_ptr(
py: Python<'py>,
ptr: *mut PyObject,
) -> Bound<'py, PyAny>
pub unsafe fn from_owned_ptr( py: Python<'py>, ptr: *mut PyObject, ) -> Bound<'py, PyAny>
Constructs a new Bound<'py, PyAny> from a pointer. Panics if ptr is null.
§Safety
ptrmust be a valid pointer to a Python objectptrmust be an owned Python reference, as theBound<'py, PyAny>will assume ownership
Sourcepub unsafe fn from_owned_ptr_or_opt(
py: Python<'py>,
ptr: *mut PyObject,
) -> Option<Bound<'py, PyAny>>
pub unsafe fn from_owned_ptr_or_opt( py: Python<'py>, ptr: *mut PyObject, ) -> Option<Bound<'py, PyAny>>
Constructs a new Bound<'py, PyAny> from a pointer. Returns None if ptr is null.
§Safety
ptrmust be a valid pointer to a Python object, or nullptrmust be an owned Python reference, as theBound<'py, PyAny>will assume ownership
Sourcepub unsafe fn from_owned_ptr_or_err(
py: Python<'py>,
ptr: *mut PyObject,
) -> Result<Bound<'py, PyAny>, PyErr>
pub unsafe fn from_owned_ptr_or_err( py: Python<'py>, ptr: *mut PyObject, ) -> Result<Bound<'py, PyAny>, PyErr>
Constructs a new Bound<'py, PyAny> from a pointer. Returns an Err by calling PyErr::fetch
if ptr is null.
§Safety
ptrmust be a valid pointer to a Python object, or nullptrmust be an owned Python reference, as theBound<'py, PyAny>will assume ownership
Sourcepub unsafe fn from_borrowed_ptr(
py: Python<'py>,
ptr: *mut PyObject,
) -> Bound<'py, PyAny>
pub unsafe fn from_borrowed_ptr( py: Python<'py>, ptr: *mut PyObject, ) -> Bound<'py, PyAny>
Constructs a new Bound<'py, PyAny> from a pointer by creating a new Python reference.
Panics if ptr is null.
§Safety
ptrmust be a valid pointer to a Python object
Sourcepub unsafe fn from_borrowed_ptr_or_opt(
py: Python<'py>,
ptr: *mut PyObject,
) -> Option<Bound<'py, PyAny>>
pub unsafe fn from_borrowed_ptr_or_opt( py: Python<'py>, ptr: *mut PyObject, ) -> Option<Bound<'py, PyAny>>
Constructs a new Bound<'py, PyAny> from a pointer by creating a new Python reference.
Returns None if ptr is null.
§Safety
ptrmust be a valid pointer to a Python object, or null
Sourcepub unsafe fn from_borrowed_ptr_or_err(
py: Python<'py>,
ptr: *mut PyObject,
) -> Result<Bound<'py, PyAny>, PyErr>
pub unsafe fn from_borrowed_ptr_or_err( py: Python<'py>, ptr: *mut PyObject, ) -> Result<Bound<'py, PyAny>, PyErr>
Constructs a new Bound<'py, PyAny> from a pointer by creating a new Python reference.
Returns an Err by calling PyErr::fetch if ptr is null.
§Safety
ptrmust be a valid pointer to a Python object, or null
Source§impl<'py, T> Bound<'py, T>where
T: PyClass,
impl<'py, T> Bound<'py, T>where
T: PyClass,
Sourcepub fn borrow(&self) -> PyRef<'py, T>
pub fn borrow(&self) -> PyRef<'py, T>
Immutably borrows the value T.
This borrow lasts while the returned PyRef exists.
Multiple immutable borrows can be taken out at the same time.
For frozen classes, the simpler get is available.
§Examples
#[pyclass]
struct Foo {
inner: u8,
}
Python::attach(|py| -> PyResult<()> {
let foo: Bound<'_, Foo> = Bound::new(py, Foo { inner: 73 })?;
let inner: &u8 = &foo.borrow().inner;
assert_eq!(*inner, 73);
Ok(())
})?;§Panics
Panics if the value is currently mutably borrowed. For a non-panicking variant, use
try_borrow.
Sourcepub fn borrow_mut(&self) -> PyRefMut<'py, T>where
T: PyClass<Frozen = False>,
pub fn borrow_mut(&self) -> PyRefMut<'py, T>where
T: PyClass<Frozen = False>,
Mutably borrows the value T.
This borrow lasts while the returned PyRefMut exists.
§Examples
#[pyclass]
struct Foo {
inner: u8,
}
Python::attach(|py| -> PyResult<()> {
let foo: Bound<'_, Foo> = Bound::new(py, Foo { inner: 73 })?;
foo.borrow_mut().inner = 35;
assert_eq!(foo.borrow().inner, 35);
Ok(())
})?;§Panics
Panics if the value is currently borrowed. For a non-panicking variant, use
try_borrow_mut.
Sourcepub fn try_borrow(&self) -> Result<PyRef<'py, T>, PyBorrowError>
pub fn try_borrow(&self) -> Result<PyRef<'py, T>, PyBorrowError>
Sourcepub fn try_borrow_mut(&self) -> Result<PyRefMut<'py, T>, PyBorrowMutError>where
T: PyClass<Frozen = False>,
pub fn try_borrow_mut(&self) -> Result<PyRefMut<'py, T>, PyBorrowMutError>where
T: PyClass<Frozen = False>,
Attempts to mutably borrow the value T, returning an error if the value is currently borrowed.
The borrow lasts while the returned PyRefMut exists.
This is the non-panicking variant of borrow_mut.
Sourcepub fn get(&self) -> &T
pub fn get(&self) -> &T
Provide an immutable borrow of the value T without acquiring the GIL.
This is available if the class is frozen and Sync.
§Examples
use std::sync::atomic::{AtomicUsize, Ordering};
#[pyclass(frozen)]
struct FrozenCounter {
value: AtomicUsize,
}
Python::attach(|py| {
let counter = FrozenCounter { value: AtomicUsize::new(0) };
let py_counter = Bound::new(py, counter).unwrap();
py_counter.get().value.fetch_add(1, Ordering::Relaxed);
});Sourcepub fn as_super(&self) -> &Bound<'py, <T as PyClassImpl>::BaseType>
pub fn as_super(&self) -> &Bound<'py, <T as PyClassImpl>::BaseType>
Upcast this Bound<PyClass> to its base type by reference.
If this type defined an explicit base class in its pyclass declaration
(e.g. #[pyclass(extends = BaseType)]), the returned type will be
&Bound<BaseType>. If an explicit base class was not declared, the
return value will be &Bound<PyAny> (making this method equivalent
to as_any).
This method is particularly useful for calling methods defined in an
extension trait that has been implemented for Bound<BaseType>.
See also the into_super method to upcast by value, and the
PyRef::as_super/PyRefMut::as_super methods for upcasting a pyclass
that has already been borrowed.
§Example: Calling a method defined on the Bound base type
use pyo3::prelude::*;
#[pyclass(subclass)]
struct BaseClass;
trait MyClassMethods<'py> {
fn pyrepr(&self) -> PyResult<String>;
}
impl<'py> MyClassMethods<'py> for Bound<'py, BaseClass> {
fn pyrepr(&self) -> PyResult<String> {
self.call_method0("__repr__")?.extract()
}
}
#[pyclass(extends = BaseClass)]
struct SubClass;
Python::attach(|py| {
let obj = Bound::new(py, (SubClass, BaseClass)).unwrap();
assert!(obj.as_super().pyrepr().is_ok());
})Sourcepub fn into_super(self) -> Bound<'py, <T as PyClassImpl>::BaseType>
pub fn into_super(self) -> Bound<'py, <T as PyClassImpl>::BaseType>
Upcast this Bound<PyClass> to its base type by value.
If this type defined an explicit base class in its pyclass declaration
(e.g. #[pyclass(extends = BaseType)]), the returned type will be
Bound<BaseType>. If an explicit base class was not declared, the
return value will be Bound<PyAny> (making this method equivalent
to into_any).
This method is particularly useful for calling methods defined in an
extension trait that has been implemented for Bound<BaseType>.
See also the as_super method to upcast by reference, and the
PyRef::into_super/PyRefMut::into_super methods for upcasting a pyclass
that has already been borrowed.
§Example: Calling a method defined on the Bound base type
use pyo3::prelude::*;
#[pyclass(subclass)]
struct BaseClass;
trait MyClassMethods<'py> {
fn pyrepr(self) -> PyResult<String>;
}
impl<'py> MyClassMethods<'py> for Bound<'py, BaseClass> {
fn pyrepr(self) -> PyResult<String> {
self.call_method0("__repr__")?.extract()
}
}
#[pyclass(extends = BaseClass)]
struct SubClass;
Python::attach(|py| {
let obj = Bound::new(py, (SubClass, BaseClass)).unwrap();
assert!(obj.into_super().pyrepr().is_ok());
})Source§impl<'py, T> Bound<'py, T>
impl<'py, T> Bound<'py, T>
Sourcepub fn as_ptr(&self) -> *mut PyObject
pub fn as_ptr(&self) -> *mut PyObject
Returns the raw FFI pointer represented by self.
§Safety
Callers are responsible for ensuring that the pointer does not outlive self.
The reference is borrowed; callers should not decrease the reference count when they are finished with the pointer.
Sourcepub fn into_ptr(self) -> *mut PyObject
pub fn into_ptr(self) -> *mut PyObject
Returns an owned raw FFI pointer represented by self.
§Safety
The reference is owned; when finished the caller should either transfer ownership
of the pointer or decrease the reference count (e.g. with pyo3::ffi::Py_DecRef).
Sourcepub fn into_any(self) -> Bound<'py, PyAny>
pub fn into_any(self) -> Bound<'py, PyAny>
Helper to cast to Bound<'py, PyAny>, transferring ownership.
Sourcepub fn as_borrowed<'a>(&'a self) -> Borrowed<'a, 'py, T>
pub fn as_borrowed<'a>(&'a self) -> Borrowed<'a, 'py, T>
Casts this Bound<T> to a Borrowed<T> smart pointer.
Sourcepub fn unbind(self) -> Py<T>
pub fn unbind(self) -> Py<T>
Removes the connection for this Bound<T> from the GIL, allowing
it to cross thread boundaries.
Sourcepub fn as_unbound(&self) -> &Py<T>
pub fn as_unbound(&self) -> &Py<T>
Removes the connection for this Bound<T> from the GIL, allowing
it to cross thread boundaries, without transferring ownership.
Source§impl<'py> Bound<'py, PyIterator>
impl<'py> Bound<'py, PyIterator>
Sourcepub fn send(
&self,
value: &Bound<'py, PyAny>,
) -> Result<PySendResult<'py>, PyErr>
pub fn send( &self, value: &Bound<'py, PyAny>, ) -> Result<PySendResult<'py>, PyErr>
Sends a value into a python generator. This is the equivalent of calling generator.send(value) in Python.
This resumes the generator and continues its execution until the next yield or return statement.
If the generator exits without returning a value, this function returns a StopException.
The first call to send must be made with None as the argument to start the generator, failing to do so will raise a TypeError.
Trait Implementations§
Source§impl<'py, T> BoundObject<'py, T> for Bound<'py, T>
impl<'py, T> BoundObject<'py, T> for Bound<'py, T>
Source§fn as_borrowed(&self) -> Borrowed<'_, 'py, T>
fn as_borrowed(&self) -> Borrowed<'_, 'py, T>
Source§fn into_bound(self) -> Bound<'py, T>
fn into_bound(self) -> Bound<'py, T>
Bound<'py, T>Source§impl<'py, T> Deref for Bound<'py, T>where
T: DerefToPyAny,
impl<'py, T> Deref for Bound<'py, T>where
T: DerefToPyAny,
Source§impl<'py, T> From<Bound<'py, T>> for PyClassInitializer<T>where
T: PyClass,
impl<'py, T> From<Bound<'py, T>> for PyClassInitializer<T>where
T: PyClass,
Source§fn from(value: Bound<'py, T>) -> PyClassInitializer<T>
fn from(value: Bound<'py, T>) -> PyClassInitializer<T>
Source§impl<'py, T> FromPyObject<'py> for Bound<'py, T>where
T: PyTypeCheck,
impl<'py, T> FromPyObject<'py> for Bound<'py, T>where
T: PyTypeCheck,
Source§impl<I> Index<I> for Bound<'_, PyBytes>where
I: SliceIndex<[u8]>,
This is the same way Vec is indexed.
impl<I> Index<I> for Bound<'_, PyBytes>where
I: SliceIndex<[u8]>,
This is the same way Vec is indexed.
Source§impl<'py> IntoIterator for &Bound<'py, PyDict>
impl<'py> IntoIterator for &Bound<'py, PyDict>
Source§impl<'py> IntoIterator for &Bound<'py, PyFrozenSet>
impl<'py> IntoIterator for &Bound<'py, PyFrozenSet>
Source§fn into_iter(self) -> <&Bound<'py, PyFrozenSet> as IntoIterator>::IntoIter ⓘ
fn into_iter(self) -> <&Bound<'py, PyFrozenSet> as IntoIterator>::IntoIter ⓘ
Returns an iterator of values in this set.
Source§type IntoIter = BoundFrozenSetIterator<'py>
type IntoIter = BoundFrozenSetIterator<'py>
Source§impl<'py> IntoIterator for &Bound<'py, PyIterator>
impl<'py> IntoIterator for &Bound<'py, PyIterator>
Source§type IntoIter = Bound<'py, PyIterator>
type IntoIter = Bound<'py, PyIterator>
Source§fn into_iter(self) -> <&Bound<'py, PyIterator> as IntoIterator>::IntoIter ⓘ
fn into_iter(self) -> <&Bound<'py, PyIterator> as IntoIterator>::IntoIter ⓘ
Source§impl<'py> IntoIterator for &Bound<'py, PyList>
impl<'py> IntoIterator for &Bound<'py, PyList>
Source§impl<'py> IntoIterator for &Bound<'py, PySet>
impl<'py> IntoIterator for &Bound<'py, PySet>
Source§impl<'py> IntoIterator for &Bound<'py, PyTuple>
impl<'py> IntoIterator for &Bound<'py, PyTuple>
Source§impl<'py> IntoIterator for Bound<'py, PyDict>
impl<'py> IntoIterator for Bound<'py, PyDict>
Source§impl<'py> IntoIterator for Bound<'py, PyFrozenSet>
impl<'py> IntoIterator for Bound<'py, PyFrozenSet>
Source§fn into_iter(self) -> <Bound<'py, PyFrozenSet> as IntoIterator>::IntoIter ⓘ
fn into_iter(self) -> <Bound<'py, PyFrozenSet> as IntoIterator>::IntoIter ⓘ
Returns an iterator of values in this set.
Source§type IntoIter = BoundFrozenSetIterator<'py>
type IntoIter = BoundFrozenSetIterator<'py>
Source§impl<'py> IntoIterator for Bound<'py, PyList>
impl<'py> IntoIterator for Bound<'py, PyList>
Source§impl<'py> IntoIterator for Bound<'py, PySet>
impl<'py> IntoIterator for Bound<'py, PySet>
Source§impl<'py> IntoIterator for Bound<'py, PyTuple>
impl<'py> IntoIterator for Bound<'py, PyTuple>
Source§impl<'a, 'py, T> IntoPyObject<'py> for &'a Bound<'py, T>
impl<'a, 'py, T> IntoPyObject<'py> for &'a Bound<'py, T>
Source§type Output = Borrowed<'a, 'py, <&'a Bound<'py, T> as IntoPyObject<'py>>::Target>
type Output = Borrowed<'a, 'py, <&'a Bound<'py, T> as IntoPyObject<'py>>::Target>
Source§type Error = Infallible
type Error = Infallible
Source§fn into_pyobject(
self,
_py: Python<'py>,
) -> Result<<&'a Bound<'py, T> as IntoPyObject<'py>>::Output, <&'a Bound<'py, T> as IntoPyObject<'py>>::Error>
fn into_pyobject( self, _py: Python<'py>, ) -> Result<<&'a Bound<'py, T> as IntoPyObject<'py>>::Output, <&'a Bound<'py, T> as IntoPyObject<'py>>::Error>
Source§impl<'py, T> IntoPyObject<'py> for Bound<'py, T>
impl<'py, T> IntoPyObject<'py> for Bound<'py, T>
Source§type Output = Bound<'py, <Bound<'py, T> as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <Bound<'py, T> as IntoPyObject<'py>>::Target>
Source§type Error = Infallible
type Error = Infallible
Source§fn into_pyobject(
self,
_py: Python<'py>,
) -> Result<<Bound<'py, T> as IntoPyObject<'py>>::Output, <Bound<'py, T> as IntoPyObject<'py>>::Error>
fn into_pyobject( self, _py: Python<'py>, ) -> Result<<Bound<'py, T> as IntoPyObject<'py>>::Output, <Bound<'py, T> as IntoPyObject<'py>>::Error>
Source§impl<'py> Iterator for Bound<'py, PyIterator>
impl<'py> Iterator for Bound<'py, PyIterator>
Source§fn next(&mut self) -> Option<<Bound<'py, PyIterator> as Iterator>::Item>
fn next(&mut self) -> Option<<Bound<'py, PyIterator> as Iterator>::Item>
Retrieves the next item from an iterator.
Returns None when the iterator is exhausted.
If an exception occurs, returns Some(Err(..)).
Further next() calls after an exception occurs are likely
to repeatedly result in the same exception.
Source§fn size_hint(&self) -> (usize, Option<usize>)
fn size_hint(&self) -> (usize, Option<usize>)
Source§fn next_chunk<const N: usize>(
&mut self,
) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>where
Self: Sized,
fn next_chunk<const N: usize>(
&mut self,
) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>where
Self: Sized,
iter_next_chunk)N values. Read more1.0.0 · Source§fn count(self) -> usizewhere
Self: Sized,
fn count(self) -> usizewhere
Self: Sized,
1.0.0 · Source§fn last(self) -> Option<Self::Item>where
Self: Sized,
fn last(self) -> Option<Self::Item>where
Self: Sized,
Source§fn advance_by(&mut self, n: usize) -> Result<(), NonZero<usize>>
fn advance_by(&mut self, n: usize) -> Result<(), NonZero<usize>>
iter_advance_by)n elements. Read more1.0.0 · Source§fn nth(&mut self, n: usize) -> Option<Self::Item>
fn nth(&mut self, n: usize) -> Option<Self::Item>
nth element of the iterator. Read more1.28.0 · Source§fn step_by(self, step: usize) -> StepBy<Self>where
Self: Sized,
fn step_by(self, step: usize) -> StepBy<Self>where
Self: Sized,
1.0.0 · Source§fn chain<U>(self, other: U) -> Chain<Self, <U as IntoIterator>::IntoIter>
fn chain<U>(self, other: U) -> Chain<Self, <U as IntoIterator>::IntoIter>
1.0.0 · Source§fn zip<U>(self, other: U) -> Zip<Self, <U as IntoIterator>::IntoIter>where
Self: Sized,
U: IntoIterator,
fn zip<U>(self, other: U) -> Zip<Self, <U as IntoIterator>::IntoIter>where
Self: Sized,
U: IntoIterator,
Source§fn intersperse(self, separator: Self::Item) -> Intersperse<Self>
fn intersperse(self, separator: Self::Item) -> Intersperse<Self>
iter_intersperse)separator between adjacent
items of the original iterator. Read moreSource§fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G>
fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G>
iter_intersperse)separator
between adjacent items of the original iterator. Read more1.0.0 · Source§fn map<B, F>(self, f: F) -> Map<Self, F>
fn map<B, F>(self, f: F) -> Map<Self, F>
1.0.0 · Source§fn filter<P>(self, predicate: P) -> Filter<Self, P>
fn filter<P>(self, predicate: P) -> Filter<Self, P>
1.0.0 · Source§fn filter_map<B, F>(self, f: F) -> FilterMap<Self, F>
fn filter_map<B, F>(self, f: F) -> FilterMap<Self, F>
1.0.0 · Source§fn enumerate(self) -> Enumerate<Self>where
Self: Sized,
fn enumerate(self) -> Enumerate<Self>where
Self: Sized,
1.0.0 · Source§fn skip_while<P>(self, predicate: P) -> SkipWhile<Self, P>
fn skip_while<P>(self, predicate: P) -> SkipWhile<Self, P>
1.0.0 · Source§fn take_while<P>(self, predicate: P) -> TakeWhile<Self, P>
fn take_while<P>(self, predicate: P) -> TakeWhile<Self, P>
1.57.0 · Source§fn map_while<B, P>(self, predicate: P) -> MapWhile<Self, P>
fn map_while<B, P>(self, predicate: P) -> MapWhile<Self, P>
1.0.0 · Source§fn skip(self, n: usize) -> Skip<Self>where
Self: Sized,
fn skip(self, n: usize) -> Skip<Self>where
Self: Sized,
n elements. Read more1.0.0 · Source§fn take(self, n: usize) -> Take<Self>where
Self: Sized,
fn take(self, n: usize) -> Take<Self>where
Self: Sized,
n elements, or fewer
if the underlying iterator ends sooner. Read more1.0.0 · Source§fn flat_map<U, F>(self, f: F) -> FlatMap<Self, U, F>
fn flat_map<U, F>(self, f: F) -> FlatMap<Self, U, F>
1.29.0 · Source§fn flatten(self) -> Flatten<Self>
fn flatten(self) -> Flatten<Self>
Source§fn map_windows<F, R, const N: usize>(self, f: F) -> MapWindows<Self, F, N>
fn map_windows<F, R, const N: usize>(self, f: F) -> MapWindows<Self, F, N>
iter_map_windows)f for each contiguous window of size N over
self and returns an iterator over the outputs of f. Like slice::windows(),
the windows during mapping overlap as well. Read more1.0.0 · Source§fn inspect<F>(self, f: F) -> Inspect<Self, F>
fn inspect<F>(self, f: F) -> Inspect<Self, F>
1.0.0 · Source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
Iterator. Read moreSource§fn try_collect<B>(
&mut self,
) -> <<Self::Item as Try>::Residual as Residual<B>>::TryType
fn try_collect<B>( &mut self, ) -> <<Self::Item as Try>::Residual as Residual<B>>::TryType
iterator_try_collect)Source§fn collect_into<E>(self, collection: &mut E) -> &mut E
fn collect_into<E>(self, collection: &mut E) -> &mut E
iter_collect_into)1.0.0 · Source§fn partition<B, F>(self, f: F) -> (B, B)
fn partition<B, F>(self, f: F) -> (B, B)
Source§fn partition_in_place<'a, T, P>(self, predicate: P) -> usize
fn partition_in_place<'a, T, P>(self, predicate: P) -> usize
iter_partition_in_place)true precede all those that return false.
Returns the number of true elements found. Read moreSource§fn is_partitioned<P>(self, predicate: P) -> bool
fn is_partitioned<P>(self, predicate: P) -> bool
iter_is_partitioned)true precede all those that return false. Read more1.27.0 · Source§fn try_fold<B, F, R>(&mut self, init: B, f: F) -> R
fn try_fold<B, F, R>(&mut self, init: B, f: F) -> R
1.27.0 · Source§fn try_for_each<F, R>(&mut self, f: F) -> R
fn try_for_each<F, R>(&mut self, f: F) -> R
1.0.0 · Source§fn fold<B, F>(self, init: B, f: F) -> B
fn fold<B, F>(self, init: B, f: F) -> B
1.51.0 · Source§fn reduce<F>(self, f: F) -> Option<Self::Item>
fn reduce<F>(self, f: F) -> Option<Self::Item>
Source§fn try_reduce<R>(
&mut self,
f: impl FnMut(Self::Item, Self::Item) -> R,
) -> <<R as Try>::Residual as Residual<Option<<R as Try>::Output>>>::TryType
fn try_reduce<R>( &mut self, f: impl FnMut(Self::Item, Self::Item) -> R, ) -> <<R as Try>::Residual as Residual<Option<<R as Try>::Output>>>::TryType
iterator_try_reduce)1.0.0 · Source§fn all<F>(&mut self, f: F) -> bool
fn all<F>(&mut self, f: F) -> bool
1.0.0 · Source§fn any<F>(&mut self, f: F) -> bool
fn any<F>(&mut self, f: F) -> bool
1.0.0 · Source§fn find<P>(&mut self, predicate: P) -> Option<Self::Item>
fn find<P>(&mut self, predicate: P) -> Option<Self::Item>
1.30.0 · Source§fn find_map<B, F>(&mut self, f: F) -> Option<B>
fn find_map<B, F>(&mut self, f: F) -> Option<B>
Source§fn try_find<R>(
&mut self,
f: impl FnMut(&Self::Item) -> R,
) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryType
fn try_find<R>( &mut self, f: impl FnMut(&Self::Item) -> R, ) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryType
try_find)1.0.0 · Source§fn position<P>(&mut self, predicate: P) -> Option<usize>
fn position<P>(&mut self, predicate: P) -> Option<usize>
1.0.0 · Source§fn rposition<P>(&mut self, predicate: P) -> Option<usize>
fn rposition<P>(&mut self, predicate: P) -> Option<usize>
1.0.0 · Source§fn max(self) -> Option<Self::Item>
fn max(self) -> Option<Self::Item>
1.0.0 · Source§fn min(self) -> Option<Self::Item>
fn min(self) -> Option<Self::Item>
1.6.0 · Source§fn max_by_key<B, F>(self, f: F) -> Option<Self::Item>
fn max_by_key<B, F>(self, f: F) -> Option<Self::Item>
1.15.0 · Source§fn max_by<F>(self, compare: F) -> Option<Self::Item>
fn max_by<F>(self, compare: F) -> Option<Self::Item>
1.6.0 · Source§fn min_by_key<B, F>(self, f: F) -> Option<Self::Item>
fn min_by_key<B, F>(self, f: F) -> Option<Self::Item>
1.15.0 · Source§fn min_by<F>(self, compare: F) -> Option<Self::Item>
fn min_by<F>(self, compare: F) -> Option<Self::Item>
1.0.0 · Source§fn rev(self) -> Rev<Self>where
Self: Sized + DoubleEndedIterator,
fn rev(self) -> Rev<Self>where
Self: Sized + DoubleEndedIterator,
1.0.0 · Source§fn unzip<A, B, FromA, FromB>(self) -> (FromA, FromB)
fn unzip<A, B, FromA, FromB>(self) -> (FromA, FromB)
1.36.0 · Source§fn copied<'a, T>(self) -> Copied<Self>
fn copied<'a, T>(self) -> Copied<Self>
Source§fn array_chunks<const N: usize>(self) -> ArrayChunks<Self, N>where
Self: Sized,
fn array_chunks<const N: usize>(self) -> ArrayChunks<Self, N>where
Self: Sized,
iter_array_chunks)N elements of the iterator at a time. Read more1.11.0 · Source§fn product<P>(self) -> P
fn product<P>(self) -> P
Source§fn cmp_by<I, F>(self, other: I, cmp: F) -> Ordering
fn cmp_by<I, F>(self, other: I, cmp: F) -> Ordering
iter_order_by)Iterator with those
of another with respect to the specified comparison function. Read more1.5.0 · Source§fn partial_cmp<I>(self, other: I) -> Option<Ordering>
fn partial_cmp<I>(self, other: I) -> Option<Ordering>
PartialOrd elements of
this Iterator with those of another. The comparison works like short-circuit
evaluation, returning a result without comparing the remaining elements.
As soon as an order can be determined, the evaluation stops and a result is returned. Read moreSource§fn partial_cmp_by<I, F>(self, other: I, partial_cmp: F) -> Option<Ordering>where
Self: Sized,
I: IntoIterator,
F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Option<Ordering>,
fn partial_cmp_by<I, F>(self, other: I, partial_cmp: F) -> Option<Ordering>where
Self: Sized,
I: IntoIterator,
F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Option<Ordering>,
iter_order_by)Iterator with those
of another with respect to the specified comparison function. Read moreSource§fn eq_by<I, F>(self, other: I, eq: F) -> bool
fn eq_by<I, F>(self, other: I, eq: F) -> bool
iter_order_by)1.5.0 · Source§fn lt<I>(self, other: I) -> bool
fn lt<I>(self, other: I) -> bool
Iterator are lexicographically
less than those of another. Read more1.5.0 · Source§fn le<I>(self, other: I) -> bool
fn le<I>(self, other: I) -> bool
Iterator are lexicographically
less or equal to those of another. Read more1.5.0 · Source§fn gt<I>(self, other: I) -> bool
fn gt<I>(self, other: I) -> bool
Iterator are lexicographically
greater than those of another. Read more1.5.0 · Source§fn ge<I>(self, other: I) -> bool
fn ge<I>(self, other: I) -> bool
Iterator are lexicographically
greater than or equal to those of another. Read more1.82.0 · Source§fn is_sorted(self) -> bool
fn is_sorted(self) -> bool
1.82.0 · Source§fn is_sorted_by<F>(self, compare: F) -> bool
fn is_sorted_by<F>(self, compare: F) -> bool
1.82.0 · Source§fn is_sorted_by_key<F, K>(self, f: F) -> bool
fn is_sorted_by_key<F, K>(self, f: F) -> bool
Source§impl PartialEq<&[u8]> for Bound<'_, PyBytes>
Compares whether the Python bytes object is equal to the u8.
impl PartialEq<&[u8]> for Bound<'_, PyBytes>
Compares whether the Python bytes object is equal to the u8.
In some cases Python equality might be more appropriate; see the note on PyBytes.
Source§impl PartialEq<&Bound<'_, PyBytes>> for [u8]
Compares whether the Python bytes object is equal to the u8.
impl PartialEq<&Bound<'_, PyBytes>> for [u8]
Compares whether the Python bytes object is equal to the u8.
In some cases Python equality might be more appropriate; see the note on PyBytes.
Source§impl PartialEq<&Bound<'_, PyString>> for str
Compares whether the data in the Python string is equal to the given UTF8.
impl PartialEq<&Bound<'_, PyString>> for str
Compares whether the data in the Python string is equal to the given UTF8.
In some cases Python equality might be more appropriate; see the note on PyString.
Source§impl PartialEq<&str> for Bound<'_, PyString>
Compares whether the data in the Python string is equal to the given UTF8.
impl PartialEq<&str> for Bound<'_, PyString>
Compares whether the data in the Python string is equal to the given UTF8.
In some cases Python equality might be more appropriate; see the note on PyString.
Source§impl PartialEq<[u8]> for &Bound<'_, PyBytes>
Compares whether the Python bytes object is equal to the u8.
impl PartialEq<[u8]> for &Bound<'_, PyBytes>
Compares whether the Python bytes object is equal to the u8.
In some cases Python equality might be more appropriate; see the note on PyBytes.
Source§impl PartialEq<[u8]> for Bound<'_, PyBytes>
Compares whether the Python bytes object is equal to the u8.
impl PartialEq<[u8]> for Bound<'_, PyBytes>
Compares whether the Python bytes object is equal to the u8.
In some cases Python equality might be more appropriate; see the note on PyBytes.
Source§impl PartialEq<Bound<'_, PyBytes>> for &[u8]
Compares whether the Python bytes object is equal to the u8.
impl PartialEq<Bound<'_, PyBytes>> for &[u8]
Compares whether the Python bytes object is equal to the u8.
In some cases Python equality might be more appropriate; see the note on PyBytes.
Source§impl PartialEq<Bound<'_, PyBytes>> for [u8]
Compares whether the Python bytes object is equal to the u8.
impl PartialEq<Bound<'_, PyBytes>> for [u8]
Compares whether the Python bytes object is equal to the u8.
In some cases Python equality might be more appropriate; see the note on PyBytes.
Source§impl PartialEq<Bound<'_, PyString>> for &str
Compares whether the data in the Python string is equal to the given UTF8.
impl PartialEq<Bound<'_, PyString>> for &str
Compares whether the data in the Python string is equal to the given UTF8.
In some cases Python equality might be more appropriate; see the note on PyString.
Source§impl PartialEq<Bound<'_, PyString>> for str
Compares whether the data in the Python string is equal to the given UTF8.
impl PartialEq<Bound<'_, PyString>> for str
Compares whether the data in the Python string is equal to the given UTF8.
In some cases Python equality might be more appropriate; see the note on PyString.
Source§impl PartialEq<str> for &Bound<'_, PyString>
Compares whether the data in the Python string is equal to the given UTF8.
impl PartialEq<str> for &Bound<'_, PyString>
Compares whether the data in the Python string is equal to the given UTF8.
In some cases Python equality might be more appropriate; see the note on PyString.
Source§impl PartialEq<str> for Bound<'_, PyString>
Compares whether the data in the Python string is equal to the given UTF8.
impl PartialEq<str> for Bound<'_, PyString>
Compares whether the data in the Python string is equal to the given UTF8.
In some cases Python equality might be more appropriate; see the note on PyString.
Source§impl<'py> PyAnyMethods<'py> for Bound<'py, PyAny>
impl<'py> PyAnyMethods<'py> for Bound<'py, PyAny>
Source§fn add<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn add<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self + other.
Source§fn sub<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn sub<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self - other.
Source§fn mul<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn mul<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self * other.
Source§fn matmul<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn matmul<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self @ other.
Source§fn div<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn div<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self / other.
Source§fn floor_div<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn floor_div<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self // other.
Source§fn rem<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn rem<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self % other.
Source§fn lshift<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn lshift<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self << other.
Source§fn rshift<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn rshift<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self >> other.
Source§fn bitand<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn bitand<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self & other.
Source§fn bitor<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn bitor<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self | other.
Source§fn bitxor<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn bitxor<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes self ^ other.
Source§fn divmod<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn divmod<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Computes divmod(self, other).
Source§fn pow<O1, O2>(
&self,
other: O1,
modulus: O2,
) -> Result<Bound<'py, PyAny>, PyErr>where
O1: IntoPyObject<'py>,
O2: IntoPyObject<'py>,
fn pow<O1, O2>(
&self,
other: O1,
modulus: O2,
) -> Result<Bound<'py, PyAny>, PyErr>where
O1: IntoPyObject<'py>,
O2: IntoPyObject<'py>,
Computes self ** other % modulus (pow(self, other, modulus)).
py.None() may be passed for the modulus.
Source§fn hasattr<N>(&self, attr_name: N) -> Result<bool, PyErr>where
N: IntoPyObject<'py, Target = PyString>,
fn hasattr<N>(&self, attr_name: N) -> Result<bool, PyErr>where
N: IntoPyObject<'py, Target = PyString>,
Source§fn getattr<N>(&self, attr_name: N) -> Result<Bound<'py, PyAny>, PyErr>where
N: IntoPyObject<'py, Target = PyString>,
fn getattr<N>(&self, attr_name: N) -> Result<Bound<'py, PyAny>, PyErr>where
N: IntoPyObject<'py, Target = PyString>,
Source§fn getattr_opt<N>(
&self,
attr_name: N,
) -> Result<Option<Bound<'py, PyAny>>, PyErr>where
N: IntoPyObject<'py, Target = PyString>,
fn getattr_opt<N>(
&self,
attr_name: N,
) -> Result<Option<Bound<'py, PyAny>>, PyErr>where
N: IntoPyObject<'py, Target = PyString>,
Source§fn setattr<N, V>(&self, attr_name: N, value: V) -> Result<(), PyErr>
fn setattr<N, V>(&self, attr_name: N, value: V) -> Result<(), PyErr>
Source§fn delattr<N>(&self, attr_name: N) -> Result<(), PyErr>where
N: IntoPyObject<'py, Target = PyString>,
fn delattr<N>(&self, attr_name: N) -> Result<(), PyErr>where
N: IntoPyObject<'py, Target = PyString>,
Source§fn rich_compare<O>(
&self,
other: O,
compare_op: CompareOp,
) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
fn rich_compare<O>(
&self,
other: O,
compare_op: CompareOp,
) -> Result<Bound<'py, PyAny>, PyErr>where
O: IntoPyObject<'py>,
Source§fn lt<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
fn lt<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
Source§fn le<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
fn le<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
Source§fn eq<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
fn eq<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
Source§fn ne<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
fn ne<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
Source§fn gt<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
fn gt<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
Source§fn ge<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
fn ge<O>(&self, other: O) -> Result<bool, PyErr>where
O: IntoPyObject<'py>,
Source§fn is_callable(&self) -> bool
fn is_callable(&self) -> bool
Source§fn call<A>(
&self,
args: A,
kwargs: Option<&Bound<'py, PyDict>>,
) -> Result<Bound<'py, PyAny>, PyErr>where
A: PyCallArgs<'py>,
fn call<A>(
&self,
args: A,
kwargs: Option<&Bound<'py, PyDict>>,
) -> Result<Bound<'py, PyAny>, PyErr>where
A: PyCallArgs<'py>,
Source§fn call0(&self) -> Result<Bound<'py, PyAny>, PyErr>
fn call0(&self) -> Result<Bound<'py, PyAny>, PyErr>
Source§fn call1<A>(&self, args: A) -> Result<Bound<'py, PyAny>, PyErr>where
A: PyCallArgs<'py>,
fn call1<A>(&self, args: A) -> Result<Bound<'py, PyAny>, PyErr>where
A: PyCallArgs<'py>,
Source§fn call_method<N, A>(
&self,
name: N,
args: A,
kwargs: Option<&Bound<'py, PyDict>>,
) -> Result<Bound<'py, PyAny>, PyErr>
fn call_method<N, A>( &self, name: N, args: A, kwargs: Option<&Bound<'py, PyDict>>, ) -> Result<Bound<'py, PyAny>, PyErr>
Source§fn call_method0<N>(&self, name: N) -> Result<Bound<'py, PyAny>, PyErr>where
N: IntoPyObject<'py, Target = PyString>,
fn call_method0<N>(&self, name: N) -> Result<Bound<'py, PyAny>, PyErr>where
N: IntoPyObject<'py, Target = PyString>,
Source§fn call_method1<N, A>(
&self,
name: N,
args: A,
) -> Result<Bound<'py, PyAny>, PyErr>
fn call_method1<N, A>( &self, name: N, args: A, ) -> Result<Bound<'py, PyAny>, PyErr>
Source§fn is_truthy(&self) -> Result<bool, PyErr>
fn is_truthy(&self) -> Result<bool, PyErr>
Source§fn is_empty(&self) -> Result<bool, PyErr>
fn is_empty(&self) -> Result<bool, PyErr>
Source§fn get_item<K>(&self, key: K) -> Result<Bound<'py, PyAny>, PyErr>where
K: IntoPyObject<'py>,
fn get_item<K>(&self, key: K) -> Result<Bound<'py, PyAny>, PyErr>where
K: IntoPyObject<'py>,
Source§fn set_item<K, V>(&self, key: K, value: V) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
V: IntoPyObject<'py>,
fn set_item<K, V>(&self, key: K, value: V) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
V: IntoPyObject<'py>,
Source§fn del_item<K>(&self, key: K) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
fn del_item<K>(&self, key: K) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
Source§fn try_iter(&self) -> Result<Bound<'py, PyIterator>, PyErr>
fn try_iter(&self) -> Result<Bound<'py, PyIterator>, PyErr>
Source§fn get_type(&self) -> Bound<'py, PyType>
fn get_type(&self) -> Bound<'py, PyType>
Source§fn get_type_ptr(&self) -> *mut PyTypeObject
fn get_type_ptr(&self) -> *mut PyTypeObject
Source§fn downcast<T>(&self) -> Result<&Bound<'py, T>, DowncastError<'_, 'py>>where
T: PyTypeCheck,
fn downcast<T>(&self) -> Result<&Bound<'py, T>, DowncastError<'_, 'py>>where
T: PyTypeCheck,
PyAny to a concrete Python type or pyclass. Read moreSource§fn downcast_into<T>(self) -> Result<Bound<'py, T>, DowncastIntoError<'py>>where
T: PyTypeCheck,
fn downcast_into<T>(self) -> Result<Bound<'py, T>, DowncastIntoError<'py>>where
T: PyTypeCheck,
Source§fn downcast_exact<T>(&self) -> Result<&Bound<'py, T>, DowncastError<'_, 'py>>where
T: PyTypeInfo,
fn downcast_exact<T>(&self) -> Result<&Bound<'py, T>, DowncastError<'_, 'py>>where
T: PyTypeInfo,
PyAny to a concrete Python type or pyclass (but not a subclass of it). Read moreSource§fn downcast_into_exact<T>(self) -> Result<Bound<'py, T>, DowncastIntoError<'py>>where
T: PyTypeInfo,
fn downcast_into_exact<T>(self) -> Result<Bound<'py, T>, DowncastIntoError<'py>>where
T: PyTypeInfo,
downcast_exact but takes ownership of self.Source§unsafe fn downcast_unchecked<T>(&self) -> &Bound<'py, T>
unsafe fn downcast_unchecked<T>(&self) -> &Bound<'py, T>
PyAny to a concrete Python type without checking validity. Read moreSource§unsafe fn downcast_into_unchecked<T>(self) -> Bound<'py, T>
unsafe fn downcast_into_unchecked<T>(self) -> Bound<'py, T>
Source§fn extract<'a, T>(&'a self) -> Result<T, PyErr>where
T: FromPyObjectBound<'a, 'py>,
fn extract<'a, T>(&'a self) -> Result<T, PyErr>where
T: FromPyObjectBound<'a, 'py>,
Source§fn get_refcnt(&self) -> isize
fn get_refcnt(&self) -> isize
Source§fn repr(&self) -> Result<Bound<'py, PyString>, PyErr>
fn repr(&self) -> Result<Bound<'py, PyString>, PyErr>
Source§fn str(&self) -> Result<Bound<'py, PyString>, PyErr>
fn str(&self) -> Result<Bound<'py, PyString>, PyErr>
Source§fn len(&self) -> Result<usize, PyErr>
fn len(&self) -> Result<usize, PyErr>
Source§fn dir(&self) -> Result<Bound<'py, PyList>, PyErr>
fn dir(&self) -> Result<Bound<'py, PyList>, PyErr>
Source§fn is_instance(&self, ty: &Bound<'py, PyAny>) -> Result<bool, PyErr>
fn is_instance(&self, ty: &Bound<'py, PyAny>) -> Result<bool, PyErr>
ty. Read moreSource§fn is_exact_instance(&self, ty: &Bound<'py, PyAny>) -> bool
fn is_exact_instance(&self, ty: &Bound<'py, PyAny>) -> bool
ty (not a subclass). Read moreSource§fn is_instance_of<T>(&self) -> boolwhere
T: PyTypeCheck,
fn is_instance_of<T>(&self) -> boolwhere
T: PyTypeCheck,
T. Read moreSource§fn is_exact_instance_of<T>(&self) -> boolwhere
T: PyTypeInfo,
fn is_exact_instance_of<T>(&self) -> boolwhere
T: PyTypeInfo,
T. Read moreSource§impl<'py> PyArrayDescrMethods<'py> for Bound<'py, PyArrayDescr>
impl<'py> PyArrayDescrMethods<'py> for Bound<'py, PyArrayDescr>
Source§fn as_dtype_ptr(&self) -> *mut PyArray_Descr
fn as_dtype_ptr(&self) -> *mut PyArray_Descr
self as *mut PyArray_Descr.Source§fn into_dtype_ptr(self) -> *mut PyArray_Descr
fn into_dtype_ptr(self) -> *mut PyArray_Descr
Source§fn is_equiv_to(&self, other: &Bound<'py, PyArrayDescr>) -> bool
fn is_equiv_to(&self, other: &Bound<'py, PyArrayDescr>) -> bool
Source§fn typeobj(&self) -> Bound<'py, PyType>
fn typeobj(&self) -> Bound<'py, PyType>
Source§fn alignment(&self) -> usize
fn alignment(&self) -> usize
Source§fn flags(&self) -> u64
fn flags(&self) -> u64
Source§fn ndim(&self) -> usize
fn ndim(&self) -> usize
Source§fn base(&self) -> Bound<'py, PyArrayDescr>
fn base(&self) -> Bound<'py, PyArrayDescr>
Source§fn has_subarray(&self) -> bool
fn has_subarray(&self) -> bool
Source§fn has_fields(&self) -> bool
fn has_fields(&self) -> bool
Source§fn names(&self) -> Option<Vec<String>>
fn names(&self) -> Option<Vec<String>>
None if there are no fields. Read moreSource§fn get_field(
&self,
name: &str,
) -> Result<(Bound<'py, PyArrayDescr>, usize), PyErr>
fn get_field( &self, name: &str, ) -> Result<(Bound<'py, PyArrayDescr>, usize), PyErr>
Source§fn num(&self) -> i32
fn num(&self) -> i32
Source§fn byteorder(&self) -> u8
fn byteorder(&self) -> u8
Source§fn char(&self) -> u8
fn char(&self) -> u8
Source§fn kind(&self) -> u8
fn kind(&self) -> u8
biufcmMOSUV) identifying the general kind of data. Read moreSource§fn has_object(&self) -> bool
fn has_object(&self) -> bool
Source§fn is_aligned_struct(&self) -> bool
fn is_aligned_struct(&self) -> bool
Source§fn is_native_byteorder(&self) -> Option<bool>
fn is_native_byteorder(&self) -> Option<bool>
None if not applicable.Source§impl<'py, T, D> PyArrayMethods<'py, T, D> for Bound<'py, PyArray<T, D>>
impl<'py, T, D> PyArrayMethods<'py, T, D> for Bound<'py, PyArray<T, D>>
Source§fn as_untyped(&self) -> &Bound<'py, PyUntypedArray>
fn as_untyped(&self) -> &Bound<'py, PyUntypedArray>
Source§unsafe fn get(&self, index: impl NpyIndex<Dim = D>) -> Option<&T>
unsafe fn get(&self, index: impl NpyIndex<Dim = D>) -> Option<&T>
Source§fn get_owned<Idx>(&self, index: Idx) -> Option<T>
fn get_owned<Idx>(&self, index: Idx) -> Option<T>
Source§fn to_dyn(&self) -> &Bound<'py, PyArray<T, Dim<IxDynImpl>>>
fn to_dyn(&self) -> &Bound<'py, PyArray<T, Dim<IxDynImpl>>>
Source§fn try_readonly(&self) -> Result<PyReadonlyArray<'py, T, D>, BorrowError>
fn try_readonly(&self) -> Result<PyReadonlyArray<'py, T, D>, BorrowError>
Source§fn try_readwrite(&self) -> Result<PyReadwriteArray<'py, T, D>, BorrowError>
fn try_readwrite(&self) -> Result<PyReadwriteArray<'py, T, D>, BorrowError>
Source§unsafe fn as_array_mut(&self) -> ArrayBase<ViewRepr<&mut T>, D>
unsafe fn as_array_mut(&self) -> ArrayBase<ViewRepr<&mut T>, D>
ArrayViewMut of the internal array. Read moreSource§fn as_raw_array(&self) -> ArrayBase<RawViewRepr<*const T>, D>
fn as_raw_array(&self) -> ArrayBase<RawViewRepr<*const T>, D>
RawArrayView enabling element access via raw pointersSource§fn as_raw_array_mut(&self) -> ArrayBase<RawViewRepr<*mut T>, D>
fn as_raw_array_mut(&self) -> ArrayBase<RawViewRepr<*mut T>, D>
RawArrayViewMut enabling element access via raw pointersSource§fn to_owned_array(&self) -> ArrayBase<OwnedRepr<T>, D>
fn to_owned_array(&self) -> ArrayBase<OwnedRepr<T>, D>
ndarray::Array. Read moreSource§fn permute<ID>(
&self,
axes: Option<ID>,
) -> Result<Bound<'py, PyArray<T, D>>, PyErr>where
ID: IntoDimension,
fn permute<ID>(
&self,
axes: Option<ID>,
) -> Result<Bound<'py, PyArray<T, D>>, PyErr>where
ID: IntoDimension,
Source§fn reshape_with_order<ID>(
&self,
shape: ID,
order: NPY_ORDER,
) -> Result<Bound<'py, PyArray<T, <ID as IntoDimension>::Dim>>, PyErr>where
ID: IntoDimension,
T: Element,
fn reshape_with_order<ID>(
&self,
shape: ID,
order: NPY_ORDER,
) -> Result<Bound<'py, PyArray<T, <ID as IntoDimension>::Dim>>, PyErr>where
ID: IntoDimension,
T: Element,
self,
but has different dimensions specified by shape
and a possibly different memory order specified by order. Read moreSource§unsafe fn resize<ID>(&self, newshape: ID) -> Result<(), PyErr>where
ID: IntoDimension,
T: Element,
unsafe fn resize<ID>(&self, newshape: ID) -> Result<(), PyErr>where
ID: IntoDimension,
T: Element,
Source§fn dims(&self) -> Dwhere
D: Dimension,
fn dims(&self) -> Dwhere
D: Dimension,
shape][PyUntypedArray::shape], but returns D instead of &[usize].Source§unsafe fn as_slice(&self) -> Result<&[T], NotContiguousError>
unsafe fn as_slice(&self) -> Result<&[T], NotContiguousError>
Source§unsafe fn as_slice_mut(&self) -> Result<&mut [T], NotContiguousError>
unsafe fn as_slice_mut(&self) -> Result<&mut [T], NotContiguousError>
Source§unsafe fn uget<Idx>(&self, index: Idx) -> &T
unsafe fn uget<Idx>(&self, index: Idx) -> &T
Source§fn readonly(&self) -> PyReadonlyArray<'py, T, D>
fn readonly(&self) -> PyReadonlyArray<'py, T, D>
Source§fn readwrite(&self) -> PyReadwriteArray<'py, T, D>
fn readwrite(&self) -> PyReadwriteArray<'py, T, D>
Source§fn cast<U>(&self, is_fortran: bool) -> Result<Bound<'py, PyArray<U, D>>, PyErr>
fn cast<U>(&self, is_fortran: bool) -> Result<Bound<'py, PyArray<U, D>>, PyErr>
cast_array insteadcast_arraySource§fn transpose(&self) -> Result<Bound<'py, PyArray<T, D>>, PyErr>where
T: Element,
fn transpose(&self) -> Result<Bound<'py, PyArray<T, D>>, PyErr>where
T: Element,
permute which reverses the order the axes.Source§fn reshape<ID>(
&self,
shape: ID,
) -> Result<Bound<'py, PyArray<T, <ID as IntoDimension>::Dim>>, PyErr>where
ID: IntoDimension,
T: Element,
fn reshape<ID>(
&self,
shape: ID,
) -> Result<Bound<'py, PyArray<T, <ID as IntoDimension>::Dim>>, PyErr>where
ID: IntoDimension,
T: Element,
reshape_with_order which keeps the memory order the same.Source§impl<'py> PyBoolMethods<'py> for Bound<'py, PyBool>
impl<'py> PyBoolMethods<'py> for Bound<'py, PyBool>
Source§impl<'py> PyByteArrayMethods<'py> for Bound<'py, PyByteArray>
impl<'py> PyByteArrayMethods<'py> for Bound<'py, PyByteArray>
Source§fn data(&self) -> *mut u8
fn data(&self) -> *mut u8
Source§unsafe fn as_bytes(&self) -> &[u8] ⓘ
unsafe fn as_bytes(&self) -> &[u8] ⓘ
ByteArray’s entire buffer. Read moreSource§unsafe fn as_bytes_mut(&self) -> &mut [u8] ⓘ
unsafe fn as_bytes_mut(&self) -> &mut [u8] ⓘ
ByteArray’s entire buffer. Read moreSource§impl<'py> PyBytesMethods<'py> for Bound<'py, PyBytes>
impl<'py> PyBytesMethods<'py> for Bound<'py, PyBytes>
Source§impl<'py> PyCapsuleMethods<'py> for Bound<'py, PyCapsule>
impl<'py> PyCapsuleMethods<'py> for Bound<'py, PyCapsule>
Source§fn set_context(&self, context: *mut c_void) -> Result<(), PyErr>
fn set_context(&self, context: *mut c_void) -> Result<(), PyErr>
Source§fn context(&self) -> Result<*mut c_void, PyErr>
fn context(&self) -> Result<*mut c_void, PyErr>
Source§unsafe fn reference<T>(&self) -> &'py T
unsafe fn reference<T>(&self) -> &'py T
Source§impl<'py> PyCodeMethods<'py> for Bound<'py, PyCode>
impl<'py> PyCodeMethods<'py> for Bound<'py, PyCode>
Source§impl<'py> PyComplexMethods<'py> for Bound<'py, PyComplex>
impl<'py> PyComplexMethods<'py> for Bound<'py, PyComplex>
Source§impl PyDateAccess for Bound<'_, PyDate>
impl PyDateAccess for Bound<'_, PyDate>
Source§impl PyDateAccess for Bound<'_, PyDateTime>
impl PyDateAccess for Bound<'_, PyDateTime>
Source§impl PyDeltaAccess for Bound<'_, PyDelta>
impl PyDeltaAccess for Bound<'_, PyDelta>
Source§fn get_days(&self) -> i32
fn get_days(&self) -> i32
Source§fn get_seconds(&self) -> i32
fn get_seconds(&self) -> i32
Source§fn get_microseconds(&self) -> i32
fn get_microseconds(&self) -> i32
Source§impl<'py> PyDictMethods<'py> for Bound<'py, PyDict>
impl<'py> PyDictMethods<'py> for Bound<'py, PyDict>
Source§fn copy(&self) -> Result<Bound<'py, PyDict>, PyErr>
fn copy(&self) -> Result<Bound<'py, PyDict>, PyErr>
Source§fn contains<K>(&self, key: K) -> Result<bool, PyErr>where
K: IntoPyObject<'py>,
fn contains<K>(&self, key: K) -> Result<bool, PyErr>where
K: IntoPyObject<'py>,
Source§fn get_item<K>(&self, key: K) -> Result<Option<Bound<'py, PyAny>>, PyErr>where
K: IntoPyObject<'py>,
fn get_item<K>(&self, key: K) -> Result<Option<Bound<'py, PyAny>>, PyErr>where
K: IntoPyObject<'py>,
Source§fn set_item<K, V>(&self, key: K, value: V) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
V: IntoPyObject<'py>,
fn set_item<K, V>(&self, key: K, value: V) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
V: IntoPyObject<'py>,
Source§fn del_item<K>(&self, key: K) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
fn del_item<K>(&self, key: K) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
Source§fn iter(&self) -> BoundDictIterator<'py>
fn iter(&self) -> BoundDictIterator<'py>
(key, value) pairs in this dictionary. Read moreSource§fn locked_for_each<F>(&self, f: F) -> Result<(), PyErr>
fn locked_for_each<F>(&self, f: F) -> Result<(), PyErr>
Source§fn as_mapping(&self) -> &Bound<'py, PyMapping>
fn as_mapping(&self) -> &Bound<'py, PyMapping>
self cast as a PyMapping.Source§fn into_mapping(self) -> Bound<'py, PyMapping>
fn into_mapping(self) -> Bound<'py, PyMapping>
self cast as a PyMapping.Source§impl<'py> PyFloatMethods<'py> for Bound<'py, PyFloat>
impl<'py> PyFloatMethods<'py> for Bound<'py, PyFloat>
Source§impl<'py> PyFrozenSetMethods<'py> for Bound<'py, PyFrozenSet>
impl<'py> PyFrozenSetMethods<'py> for Bound<'py, PyFrozenSet>
Source§impl<'py> PyListMethods<'py> for Bound<'py, PyList>
impl<'py> PyListMethods<'py> for Bound<'py, PyList>
Source§fn as_sequence(&self) -> &Bound<'py, PySequence>
fn as_sequence(&self) -> &Bound<'py, PySequence>
Returns self cast as a PySequence.
Source§fn into_sequence(self) -> Bound<'py, PySequence>
fn into_sequence(self) -> Bound<'py, PySequence>
Returns self cast as a PySequence.
Source§fn get_item(&self, index: usize) -> Result<Bound<'py, PyAny>, PyErr>
fn get_item(&self, index: usize) -> Result<Bound<'py, PyAny>, PyErr>
Gets the list item at the specified index.
§Example
use pyo3::{prelude::*, types::PyList};
Python::attach(|py| {
let list = PyList::new(py, [2, 3, 5, 7]).unwrap();
let obj = list.get_item(0);
assert_eq!(obj.unwrap().extract::<i32>().unwrap(), 2);
});Source§unsafe fn get_item_unchecked(&self, index: usize) -> Bound<'py, PyAny>
unsafe fn get_item_unchecked(&self, index: usize) -> Bound<'py, PyAny>
Gets the list item at the specified index. Undefined behavior on bad index. Use with caution.
§Safety
Caller must verify that the index is within the bounds of the list.
Source§fn get_slice(&self, low: usize, high: usize) -> Bound<'py, PyList>
fn get_slice(&self, low: usize, high: usize) -> Bound<'py, PyList>
Takes the slice self[low:high] and returns it as a new list.
Indices must be nonnegative, and out-of-range indices are clipped to
self.len().
Source§fn set_item<I>(&self, index: usize, item: I) -> Result<(), PyErr>where
I: IntoPyObject<'py>,
fn set_item<I>(&self, index: usize, item: I) -> Result<(), PyErr>where
I: IntoPyObject<'py>,
Sets the item at the specified index.
Raises IndexError if the index is out of range.
Source§fn del_item(&self, index: usize) -> Result<(), PyErr>
fn del_item(&self, index: usize) -> Result<(), PyErr>
Deletes the indexth element of self.
This is equivalent to the Python statement del self[i].
Source§fn set_slice(
&self,
low: usize,
high: usize,
seq: &Bound<'_, PyAny>,
) -> Result<(), PyErr>
fn set_slice( &self, low: usize, high: usize, seq: &Bound<'_, PyAny>, ) -> Result<(), PyErr>
Assigns the sequence seq to the slice of self from low to high.
This is equivalent to the Python statement self[low:high] = v.
Source§fn del_slice(&self, low: usize, high: usize) -> Result<(), PyErr>
fn del_slice(&self, low: usize, high: usize) -> Result<(), PyErr>
Deletes the slice from low to high from self.
This is equivalent to the Python statement del self[low:high].
Source§fn append<I>(&self, item: I) -> Result<(), PyErr>where
I: IntoPyObject<'py>,
fn append<I>(&self, item: I) -> Result<(), PyErr>where
I: IntoPyObject<'py>,
Appends an item to the list.
Source§fn insert<I>(&self, index: usize, item: I) -> Result<(), PyErr>where
I: IntoPyObject<'py>,
fn insert<I>(&self, index: usize, item: I) -> Result<(), PyErr>where
I: IntoPyObject<'py>,
Inserts an item at the specified index.
If index >= self.len(), inserts at the end.
Source§fn contains<V>(&self, value: V) -> Result<bool, PyErr>where
V: IntoPyObject<'py>,
fn contains<V>(&self, value: V) -> Result<bool, PyErr>where
V: IntoPyObject<'py>,
Determines if self contains value.
This is equivalent to the Python expression value in self.
Source§fn index<V>(&self, value: V) -> Result<usize, PyErr>where
V: IntoPyObject<'py>,
fn index<V>(&self, value: V) -> Result<usize, PyErr>where
V: IntoPyObject<'py>,
Returns the first index i for which self[i] == value.
This is equivalent to the Python expression self.index(value).
Source§fn iter(&self) -> BoundListIterator<'py>
fn iter(&self) -> BoundListIterator<'py>
Returns an iterator over this list’s items.
Source§fn locked_for_each<F>(&self, closure: F) -> Result<(), PyErr>
fn locked_for_each<F>(&self, closure: F) -> Result<(), PyErr>
Iterates over a list while holding a critical section, calling a closure on each item
Source§fn sort(&self) -> Result<(), PyErr>
fn sort(&self) -> Result<(), PyErr>
Sorts the list in-place. Equivalent to the Python expression l.sort().
Source§impl<'py> PyMappingMethods<'py> for Bound<'py, PyMapping>
impl<'py> PyMappingMethods<'py> for Bound<'py, PyMapping>
Source§fn contains<K>(&self, key: K) -> Result<bool, PyErr>where
K: IntoPyObject<'py>,
fn contains<K>(&self, key: K) -> Result<bool, PyErr>where
K: IntoPyObject<'py>,
Source§fn get_item<K>(&self, key: K) -> Result<Bound<'py, PyAny>, PyErr>where
K: IntoPyObject<'py>,
fn get_item<K>(&self, key: K) -> Result<Bound<'py, PyAny>, PyErr>where
K: IntoPyObject<'py>,
key. Read moreSource§fn set_item<K, V>(&self, key: K, value: V) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
V: IntoPyObject<'py>,
fn set_item<K, V>(&self, key: K, value: V) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
V: IntoPyObject<'py>,
key. Read moreSource§fn del_item<K>(&self, key: K) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
fn del_item<K>(&self, key: K) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
key. Read moreSource§fn keys(&self) -> Result<Bound<'py, PyList>, PyErr>
fn keys(&self) -> Result<Bound<'py, PyList>, PyErr>
Source§impl<'py, 'a> PyMappingProxyMethods<'py, 'a> for Bound<'py, PyMappingProxy>
impl<'py, 'a> PyMappingProxyMethods<'py, 'a> for Bound<'py, PyMappingProxy>
Source§fn is_empty(&self) -> Result<bool, PyErr>
fn is_empty(&self) -> Result<bool, PyErr>
len(self) == 0.Source§fn keys(&self) -> Result<Bound<'py, PyList>, PyErr>
fn keys(&self) -> Result<Bound<'py, PyList>, PyErr>
Source§fn values(&self) -> Result<Bound<'py, PyList>, PyErr>
fn values(&self) -> Result<Bound<'py, PyList>, PyErr>
Source§fn items(&self) -> Result<Bound<'py, PyList>, PyErr>
fn items(&self) -> Result<Bound<'py, PyList>, PyErr>
Source§fn as_mapping(&self) -> &Bound<'py, PyMapping>
fn as_mapping(&self) -> &Bound<'py, PyMapping>
self cast as a PyMapping.Source§impl<'py> PyModuleMethods<'py> for Bound<'py, PyModule>
impl<'py> PyModuleMethods<'py> for Bound<'py, PyModule>
Source§fn dict(&self) -> Bound<'py, PyDict>
fn dict(&self) -> Bound<'py, PyDict>
__dict__ attribute, which contains the module’s symbol table.Source§fn index(&self) -> Result<Bound<'py, PyList>, PyErr>
fn index(&self) -> Result<Bound<'py, PyList>, PyErr>
__all__ attribute) of the module,
creating one if needed. Read moreSource§fn name(&self) -> Result<Bound<'py, PyString>, PyErr>
fn name(&self) -> Result<Bound<'py, PyString>, PyErr>
__name__ attribute) of the module. Read moreSource§fn filename(&self) -> Result<Bound<'py, PyString>, PyErr>
fn filename(&self) -> Result<Bound<'py, PyString>, PyErr>
__file__ attribute) of the module. Read moreSource§fn add<N, V>(&self, name: N, value: V) -> Result<(), PyErr>
fn add<N, V>(&self, name: N, value: V) -> Result<(), PyErr>
Source§fn add_class<T>(&self) -> Result<(), PyErr>where
T: PyClass,
fn add_class<T>(&self) -> Result<(), PyErr>where
T: PyClass,
Source§fn add_wrapped<T>(
&self,
wrapper: &impl Fn(Python<'py>) -> T,
) -> Result<(), PyErr>
fn add_wrapped<T>( &self, wrapper: &impl Fn(Python<'py>) -> T, ) -> Result<(), PyErr>
Source§fn add_submodule(&self, module: &Bound<'_, PyModule>) -> Result<(), PyErr>
fn add_submodule(&self, module: &Bound<'_, PyModule>) -> Result<(), PyErr>
Source§fn add_function(&self, fun: Bound<'_, PyCFunction>) -> Result<(), PyErr>
fn add_function(&self, fun: Bound<'_, PyCFunction>) -> Result<(), PyErr>
Source§impl<'py> PyRangeMethods<'py> for Bound<'py, PyRange>
impl<'py> PyRangeMethods<'py> for Bound<'py, PyRange>
Source§impl<'py> PySequenceMethods<'py> for Bound<'py, PySequence>
impl<'py> PySequenceMethods<'py> for Bound<'py, PySequence>
Source§fn concat(
&self,
other: &Bound<'_, PySequence>,
) -> Result<Bound<'py, PySequence>, PyErr>
fn concat( &self, other: &Bound<'_, PySequence>, ) -> Result<Bound<'py, PySequence>, PyErr>
Source§fn repeat(&self, count: usize) -> Result<Bound<'py, PySequence>, PyErr>
fn repeat(&self, count: usize) -> Result<Bound<'py, PySequence>, PyErr>
count times. Read moreSource§fn in_place_concat(
&self,
other: &Bound<'_, PySequence>,
) -> Result<Bound<'py, PySequence>, PyErr>
fn in_place_concat( &self, other: &Bound<'_, PySequence>, ) -> Result<Bound<'py, PySequence>, PyErr>
Source§fn in_place_repeat(&self, count: usize) -> Result<Bound<'py, PySequence>, PyErr>
fn in_place_repeat(&self, count: usize) -> Result<Bound<'py, PySequence>, PyErr>
Source§fn get_item(&self, index: usize) -> Result<Bound<'py, PyAny>, PyErr>
fn get_item(&self, index: usize) -> Result<Bound<'py, PyAny>, PyErr>
indexth element of the Sequence. Read moreSource§fn count<V>(&self, value: V) -> Result<usize, PyErr>where
V: IntoPyObject<'py>,
fn count<V>(&self, value: V) -> Result<usize, PyErr>where
V: IntoPyObject<'py>,
value in self, that is, return the
number of keys for which self[key] == value.Source§fn contains<V>(&self, value: V) -> Result<bool, PyErr>where
V: IntoPyObject<'py>,
fn contains<V>(&self, value: V) -> Result<bool, PyErr>where
V: IntoPyObject<'py>,
value. Read moreSource§impl<'py> PySetMethods<'py> for Bound<'py, PySet>
impl<'py> PySetMethods<'py> for Bound<'py, PySet>
Source§fn contains<K>(&self, key: K) -> Result<bool, PyErr>where
K: IntoPyObject<'py>,
fn contains<K>(&self, key: K) -> Result<bool, PyErr>where
K: IntoPyObject<'py>,
Source§fn discard<K>(&self, key: K) -> Result<bool, PyErr>where
K: IntoPyObject<'py>,
fn discard<K>(&self, key: K) -> Result<bool, PyErr>where
K: IntoPyObject<'py>,
Source§fn add<K>(&self, key: K) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
fn add<K>(&self, key: K) -> Result<(), PyErr>where
K: IntoPyObject<'py>,
Source§fn pop(&self) -> Option<Bound<'py, PyAny>>
fn pop(&self) -> Option<Bound<'py, PyAny>>
Source§fn iter(&self) -> BoundSetIterator<'py>
fn iter(&self) -> BoundSetIterator<'py>
Source§impl<'py> PySliceMethods<'py> for Bound<'py, PySlice>
impl<'py> PySliceMethods<'py> for Bound<'py, PySlice>
Source§impl<'py> PyStringMethods<'py> for Bound<'py, PyString>
impl<'py> PyStringMethods<'py> for Bound<'py, PyString>
Source§fn to_str(&self) -> Result<&str, PyErr>
fn to_str(&self) -> Result<&str, PyErr>
Source§fn to_cow(&self) -> Result<Cow<'_, str>, PyErr>
fn to_cow(&self) -> Result<Cow<'_, str>, PyErr>
PyString into a Rust string, avoiding copying when possible. Read moreSource§impl PyTimeAccess for Bound<'_, PyDateTime>
impl PyTimeAccess for Bound<'_, PyDateTime>
Source§fn get_minute(&self) -> u8
fn get_minute(&self) -> u8
Source§fn get_second(&self) -> u8
fn get_second(&self) -> u8
Source§fn get_microsecond(&self) -> u32
fn get_microsecond(&self) -> u32
Source§impl PyTimeAccess for Bound<'_, PyTime>
impl PyTimeAccess for Bound<'_, PyTime>
Source§fn get_minute(&self) -> u8
fn get_minute(&self) -> u8
Source§fn get_second(&self) -> u8
fn get_second(&self) -> u8
Source§fn get_microsecond(&self) -> u32
fn get_microsecond(&self) -> u32
Source§impl<'py> PyTracebackMethods<'py> for Bound<'py, PyTraceback>
impl<'py> PyTracebackMethods<'py> for Bound<'py, PyTraceback>
Source§impl<'py> PyTupleMethods<'py> for Bound<'py, PyTuple>
impl<'py> PyTupleMethods<'py> for Bound<'py, PyTuple>
Source§fn as_sequence(&self) -> &Bound<'py, PySequence>
fn as_sequence(&self) -> &Bound<'py, PySequence>
self cast as a PySequence.Source§fn into_sequence(self) -> Bound<'py, PySequence>
fn into_sequence(self) -> Bound<'py, PySequence>
self cast as a PySequence.Source§fn get_slice(&self, low: usize, high: usize) -> Bound<'py, PyTuple>
fn get_slice(&self, low: usize, high: usize) -> Bound<'py, PyTuple>
self[low:high] and returns it as a new tuple. Read moreSource§fn get_item(&self, index: usize) -> Result<Bound<'py, PyAny>, PyErr>
fn get_item(&self, index: usize) -> Result<Bound<'py, PyAny>, PyErr>
Source§fn get_borrowed_item<'a>(
&'a self,
index: usize,
) -> Result<Borrowed<'a, 'py, PyAny>, PyErr>
fn get_borrowed_item<'a>( &'a self, index: usize, ) -> Result<Borrowed<'a, 'py, PyAny>, PyErr>
get_item, but returns a borrowed object, which is a slight performance optimization
by avoiding a reference count change.Source§unsafe fn get_item_unchecked(&self, index: usize) -> Bound<'py, PyAny>
unsafe fn get_item_unchecked(&self, index: usize) -> Bound<'py, PyAny>
Source§unsafe fn get_borrowed_item_unchecked<'a>(
&'a self,
index: usize,
) -> Borrowed<'a, 'py, PyAny>
unsafe fn get_borrowed_item_unchecked<'a>( &'a self, index: usize, ) -> Borrowed<'a, 'py, PyAny>
get_item_unchecked, but returns a borrowed object,
which is a slight performance optimization by avoiding a reference count change. Read moreSource§fn contains<V>(&self, value: V) -> Result<bool, PyErr>where
V: IntoPyObject<'py>,
fn contains<V>(&self, value: V) -> Result<bool, PyErr>where
V: IntoPyObject<'py>,
value. Read moreSource§fn iter(&self) -> BoundTupleIterator<'py>
fn iter(&self) -> BoundTupleIterator<'py>
Source§fn iter_borrowed<'a>(&'a self) -> BorrowedTupleIterator<'a, 'py>
fn iter_borrowed<'a>(&'a self) -> BorrowedTupleIterator<'a, 'py>
iter, but produces an iterator which returns borrowed objects,
which is a slight performance optimization by avoiding a reference count change.Source§impl<'py> PyTypeMethods<'py> for Bound<'py, PyType>
impl<'py> PyTypeMethods<'py> for Bound<'py, PyType>
Source§fn as_type_ptr(&self) -> *mut PyTypeObject
fn as_type_ptr(&self) -> *mut PyTypeObject
Retrieves the underlying FFI pointer associated with this Python object.
Source§fn qualname(&self) -> Result<Bound<'py, PyString>, PyErr>
fn qualname(&self) -> Result<Bound<'py, PyString>, PyErr>
Gets the qualified name of the PyType.
Source§fn module(&self) -> Result<Bound<'py, PyString>, PyErr>
fn module(&self) -> Result<Bound<'py, PyString>, PyErr>
Gets the name of the module defining the PyType.
Source§fn fully_qualified_name(&self) -> Result<Bound<'py, PyString>, PyErr>
fn fully_qualified_name(&self) -> Result<Bound<'py, PyString>, PyErr>
Gets the fully qualified name of the PyType.
Source§fn is_subclass(&self, other: &Bound<'_, PyAny>) -> Result<bool, PyErr>
fn is_subclass(&self, other: &Bound<'_, PyAny>) -> Result<bool, PyErr>
Checks whether self is a subclass of other.
Equivalent to the Python expression issubclass(self, other).
Source§fn is_subclass_of<T>(&self) -> Result<bool, PyErr>where
T: PyTypeInfo,
fn is_subclass_of<T>(&self) -> Result<bool, PyErr>where
T: PyTypeInfo,
Checks whether self is a subclass of type T.
Equivalent to the Python expression issubclass(self, T), if the type
T is known at compile time.
Source§impl<'py> PyTzInfoAccess<'py> for Bound<'py, PyDateTime>
impl<'py> PyTzInfoAccess<'py> for Bound<'py, PyDateTime>
Source§impl<'py> PyTzInfoAccess<'py> for Bound<'py, PyTime>
impl<'py> PyTzInfoAccess<'py> for Bound<'py, PyTime>
Source§impl<'py, T, D> PyUntypedArrayMethods<'py> for Bound<'py, PyArray<T, D>>
impl<'py, T, D> PyUntypedArrayMethods<'py> for Bound<'py, PyArray<T, D>>
Source§fn as_array_ptr(&self) -> *mut PyArrayObject
fn as_array_ptr(&self) -> *mut PyArrayObject
PyArrayObject.Source§fn is_contiguous(&self) -> bool
fn is_contiguous(&self) -> bool
true if the internal data of the array is contiguous,
indepedently of whether C-style/row-major or Fortran-style/column-major. Read moreSource§fn is_fortran_contiguous(&self) -> bool
fn is_fortran_contiguous(&self) -> bool
true if the internal data of the array is Fortran-style/column-major contiguous.Source§fn is_c_contiguous(&self) -> bool
fn is_c_contiguous(&self) -> bool
true if the internal data of the array is C-style/row-major contiguous.Source§fn strides(&self) -> &[isize]
fn strides(&self) -> &[isize]
Source§impl<'py> PyUntypedArrayMethods<'py> for Bound<'py, PyUntypedArray>
impl<'py> PyUntypedArrayMethods<'py> for Bound<'py, PyUntypedArray>
Source§fn as_array_ptr(&self) -> *mut PyArrayObject
fn as_array_ptr(&self) -> *mut PyArrayObject
PyArrayObject.Source§fn is_contiguous(&self) -> bool
fn is_contiguous(&self) -> bool
true if the internal data of the array is contiguous,
indepedently of whether C-style/row-major or Fortran-style/column-major. Read moreSource§fn is_fortran_contiguous(&self) -> bool
fn is_fortran_contiguous(&self) -> bool
true if the internal data of the array is Fortran-style/column-major contiguous.Source§fn is_c_contiguous(&self) -> bool
fn is_c_contiguous(&self) -> bool
true if the internal data of the array is C-style/row-major contiguous.Source§fn strides(&self) -> &[isize]
fn strides(&self) -> &[isize]
Source§impl<'py> PyWeakrefMethods<'py> for Bound<'py, PyWeakref>
impl<'py> PyWeakrefMethods<'py> for Bound<'py, PyWeakref>
Source§fn upgrade_as<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeCheck,
fn upgrade_as<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeCheck,
Source§unsafe fn upgrade_as_unchecked<T>(&self) -> Option<Bound<'py, T>>
unsafe fn upgrade_as_unchecked<T>(&self) -> Option<Bound<'py, T>>
weakref may still return None. Read moreSource§fn upgrade_as_exact<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeInfo,
fn upgrade_as_exact<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeInfo,
Source§impl<'py> PyWeakrefMethods<'py> for Bound<'py, PyWeakrefProxy>
impl<'py> PyWeakrefMethods<'py> for Bound<'py, PyWeakrefProxy>
Source§fn upgrade_as<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeCheck,
fn upgrade_as<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeCheck,
Source§unsafe fn upgrade_as_unchecked<T>(&self) -> Option<Bound<'py, T>>
unsafe fn upgrade_as_unchecked<T>(&self) -> Option<Bound<'py, T>>
weakref may still return None. Read moreSource§fn upgrade_as_exact<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeInfo,
fn upgrade_as_exact<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeInfo,
Source§impl<'py> PyWeakrefMethods<'py> for Bound<'py, PyWeakrefReference>
impl<'py> PyWeakrefMethods<'py> for Bound<'py, PyWeakrefReference>
Source§fn upgrade_as<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeCheck,
fn upgrade_as<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeCheck,
Source§unsafe fn upgrade_as_unchecked<T>(&self) -> Option<Bound<'py, T>>
unsafe fn upgrade_as_unchecked<T>(&self) -> Option<Bound<'py, T>>
weakref may still return None. Read moreSource§fn upgrade_as_exact<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeInfo,
fn upgrade_as_exact<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>where
T: PyTypeInfo,
Source§impl<'py> TryFrom<&Bound<'py, PyAny>> for Bound<'py, PyByteArray>
impl<'py> TryFrom<&Bound<'py, PyAny>> for Bound<'py, PyByteArray>
Source§impl<'py> TryFrom<&Bound<'py, PyAny>> for Bound<'py, PyMemoryView>
impl<'py> TryFrom<&Bound<'py, PyAny>> for Bound<'py, PyMemoryView>
impl<'py> PyCallArgs<'py> for &Bound<'py, PyTuple>
impl<'py> PyCallArgs<'py> for Bound<'py, PyTuple>
Auto Trait Implementations§
impl<'py, T> Freeze for Bound<'py, T>
impl<'py, T> RefUnwindSafe for Bound<'py, T>where
T: RefUnwindSafe,
impl<'py, T> !Send for Bound<'py, T>
impl<'py, T> !Sync for Bound<'py, T>
impl<'py, T> Unpin for Bound<'py, T>where
T: Unpin,
impl<'py, T> UnwindSafe for Bound<'py, T>where
T: UnwindSafe,
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<'py, T> FromPyObjectBound<'_, 'py> for Twhere
T: FromPyObject<'py>,
impl<'py, T> FromPyObjectBound<'_, 'py> for Twhere
T: FromPyObject<'py>,
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>
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>
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<I> IntoIterator for Iwhere
I: Iterator,
impl<I> IntoIterator for Iwhere
I: Iterator,
Source§impl<'py, T, I> IntoPyDict<'py> for Iwhere
T: PyDictItem<'py>,
I: IntoIterator<Item = T>,
impl<'py, T, I> IntoPyDict<'py> for Iwhere
T: PyDictItem<'py>,
I: IntoIterator<Item = T>,
Source§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>
self into an owned Python object, dropping type information.