devela::_dep::pyo3

Struct Bound

pub struct Bound<'py, T>(/* private fields */);
Available on crate features dep_pyo3 and std only.
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::allow_threads’s closure.

See the guide for more detail.

Implementations§

§

impl<'py, T> Bound<'py, T>
where T: PyClass,

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::with_gil(|py| -> PyResult<_> {
    let foo: Bound<'_, Foo> = Bound::new(py, Foo {})?;
    Ok(foo.into())
})?;
§

impl<'py> 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
  • ptr must be a valid pointer to a Python object
  • ptr must be an owned Python reference, as the Bound<'py, PyAny> will assume ownership

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
  • ptr must be a valid pointer to a Python object, or null
  • ptr must be an owned Python reference, as the Bound<'py, PyAny> will assume ownership

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
  • ptr must be a valid pointer to a Python object, or null
  • ptr must be an owned Python reference, as the Bound<'py, PyAny> will assume ownership

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
  • ptr must be a valid pointer to a Python object

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
  • ptr must be a valid pointer to a Python object, or null

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
  • ptr must be a valid pointer to a Python object, or null
§

impl<'py, T> Bound<'py, T>
where T: PyClass,

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::with_gil(|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.

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::with_gil(|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.

pub fn try_borrow(&self) -> Result<PyRef<'py, T>, PyBorrowError>

Attempts to immutably borrow the value T, returning an error if the value is currently mutably borrowed.

The borrow lasts while the returned PyRef exists.

This is the non-panicking variant of borrow.

For frozen classes, the simpler get is available.

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.

pub fn get(&self) -> &T
where T: PyClass<Frozen = True> + Sync,

Provide an immutable borrow of the value T without acquiring the GIL.

This is available if the class is [frozen][macro@crate::pyclass] and Sync.

§Examples
use std::sync::atomic::{AtomicUsize, Ordering};

#[pyclass(frozen)]
struct FrozenCounter {
    value: AtomicUsize,
}

Python::with_gil(|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);
});

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::with_gil(|py| {
    let obj = Bound::new(py, (SubClass, BaseClass)).unwrap();
    assert!(obj.as_super().pyrepr().is_ok());
})

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::with_gil(|py| {
    let obj = Bound::new(py, (SubClass, BaseClass)).unwrap();
    assert!(obj.into_super().pyrepr().is_ok());
})
§

impl<'py, T> Bound<'py, T>

pub fn py(&self) -> Python<'py>

Returns the GIL token associated with this object.

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.

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).

pub fn as_any(&self) -> &Bound<'py, PyAny>

Helper to cast to Bound<'py, PyAny>.

pub fn into_any(self) -> Bound<'py, PyAny>

Helper to cast to Bound<'py, PyAny>, transferring ownership.

pub fn as_borrowed<'a>(&'a self) -> Borrowed<'a, 'py, T>

Casts this Bound<T> to a Borrowed<T> smart pointer.

pub fn unbind(self) -> Py<T>

Removes the connection for this Bound<T> from the GIL, allowing it to cross thread boundaries.

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.

Trait Implementations§

§

impl<'py> Add<&Bound<'py, PyComplex>> for Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the + operator.
§

fn add(self, other: &Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the + operation. Read more
§

impl<'py> Add<Bound<'py, PyComplex>> for &Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the + operator.
§

fn add(self, other: Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the + operation. Read more
§

impl<'py> Add for &Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the + operator.
§

fn add(self, other: &Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the + operation. Read more
§

impl<'py> Add for Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the + operator.
§

fn add(self, other: Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the + operation. Read more
§

impl<T> AsPyPointer for Bound<'_, T>

§

fn as_ptr(&self) -> *mut PyObject

Returns the underlying FFI pointer as a borrowed pointer.
§

impl<'py, T> AsRef<Bound<'py, PyAny>> for Bound<'py, T>

§

fn as_ref(&self) -> &Bound<'py, PyAny>

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

impl<'py, T> BoundObject<'py, T> for Bound<'py, T>

§

type Any = Bound<'py, PyAny>

Type erased version of Self
§

fn as_borrowed(&self) -> Borrowed<'_, 'py, T>

Borrow this smart pointer.
§

fn into_bound(self) -> Bound<'py, T>

Turns this smart pointer into an owned [Bound<'py, T>]
§

fn into_any(self) -> <Bound<'py, T> as BoundObject<'py, T>>::Any

Upcast the target type of this smart pointer
§

fn into_ptr(self) -> *mut PyObject

Turn this smart pointer into a strong reference pointer
§

fn as_ptr(&self) -> *mut PyObject

Turn this smart pointer into a borrowed reference pointer
§

fn unbind(self) -> Py<T>

Turn this smart pointer into an owned Py<T>
§

impl<T> Clone for Bound<'_, T>

§

fn clone(&self) -> Bound<'_, T>

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
§

impl<T> Debug for Bound<'_, T>

§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
§

impl<'py, T> Deref for Bound<'py, T>
where T: DerefToPyAny,

§

type Target = Bound<'py, PyAny>

The resulting type after dereferencing.
§

fn deref(&self) -> &Bound<'py, PyAny>

Dereferences the value.
§

impl<T> Display for Bound<'_, T>

§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
§

impl<'py> Div<&Bound<'py, PyComplex>> for Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the / operator.
§

fn div(self, other: &Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the / operation. Read more
§

impl<'py> Div<Bound<'py, PyComplex>> for &Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the / operator.
§

fn div(self, other: Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the / operation. Read more
§

impl<'py> Div for &Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the / operator.
§

fn div(self, other: &Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the / operation. Read more
§

impl<'py> Div for Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the / operator.
§

fn div(self, other: Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the / operation. Read more
§

impl<T> Drop for Bound<'_, T>

§

fn drop(&mut self)

Executes the destructor for this type. Read more
§

impl<'a, 'py, T> From<&'a Bound<'py, T>> for Borrowed<'a, 'py, T>

§

fn from(instance: &'a Bound<'py, T>) -> Borrowed<'a, 'py, T>

Create borrow on a Bound

§

impl From<Bound<'_, PyByteArray>> for PyBackedBytes

§

fn from(py_bytearray: Bound<'_, PyByteArray>) -> PyBackedBytes

Converts to this type from the input type.
§

impl From<Bound<'_, PyBytes>> for PyBackedBytes

§

fn from(py_bytes: Bound<'_, PyBytes>) -> PyBackedBytes

Converts to this type from the input type.
§

impl<T> From<Bound<'_, T>> for Py<PyAny>
where T: AsRef<PyAny>,

§

fn from(other: Bound<'_, T>) -> Py<PyAny>

Converts to this type from the input type.
§

impl<T> From<Bound<'_, T>> for Py<T>

§

fn from(other: Bound<'_, T>) -> Py<T>

Converts to this type from the input type.
§

impl<'py, T> From<Bound<'py, T>> for PyClassInitializer<T>
where T: PyClass,

§

fn from(value: Bound<'py, T>) -> PyClassInitializer<T>

Converts to this type from the input type.
§

impl<'py, T> From<Bound<'py, T>> for PyErr
where T: ToPyErr,

§

fn from(err: Bound<'py, T>) -> PyErr

Converts to this type from the input type.
§

impl<'a, 'py, T> From<BoundRef<'a, 'py, T>> for &'a Bound<'py, T>

§

fn from(bound: BoundRef<'a, 'py, T>) -> &'a Bound<'py, T>

Converts to this type from the input type.
§

impl<'a, 'py, T> From<BoundRef<'a, 'py, T>> for Bound<'py, T>

§

fn from(bound: BoundRef<'a, 'py, T>) -> Bound<'py, T>

Converts to this type from the input type.
§

impl<'py, T> FromPyObject<'py> for Bound<'py, T>
where T: PyTypeCheck,

§

fn extract_bound(ob: &Bound<'py, PyAny>) -> Result<Bound<'py, T>, PyErr>

Extracts Self from the source PyObject.

§

impl<I> Index<I> for Bound<'_, PyBytes>
where I: SliceIndex<[u8]>,

This is the same way Vec is indexed.

§

type Output = <I as SliceIndex<[u8]>>::Output

The returned type after indexing.
§

fn index(&self, index: I) -> &<Bound<'_, PyBytes> as Index<I>>::Output

Performs the indexing (container[index]) operation. Read more
§

impl<'py> IntoIterator for &Bound<'py, PyDict>

§

type Item = (Bound<'py, PyAny>, Bound<'py, PyAny>)

The type of the elements being iterated over.
§

type IntoIter = BoundDictIterator<'py>

Which kind of iterator are we turning this into?
§

fn into_iter(self) -> <&Bound<'py, PyDict> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
§

impl<'py> IntoIterator for &Bound<'py, PyFrozenSet>

§

fn into_iter(self) -> <&Bound<'py, PyFrozenSet> as IntoIterator>::IntoIter

Returns an iterator of values in this set.

§

type Item = Bound<'py, PyAny>

The type of the elements being iterated over.
§

type IntoIter = BoundFrozenSetIterator<'py>

Which kind of iterator are we turning this into?
§

impl<'py> IntoIterator for &Bound<'py, PyIterator>

§

type Item = Result<Bound<'py, PyAny>, PyErr>

The type of the elements being iterated over.
§

type IntoIter = Bound<'py, PyIterator>

Which kind of iterator are we turning this into?
§

fn into_iter(self) -> <&Bound<'py, PyIterator> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
§

impl<'py> IntoIterator for &Bound<'py, PyList>

§

type Item = Bound<'py, PyAny>

The type of the elements being iterated over.
§

type IntoIter = BoundListIterator<'py>

Which kind of iterator are we turning this into?
§

fn into_iter(self) -> <&Bound<'py, PyList> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
§

impl<'py> IntoIterator for &Bound<'py, PySet>

§

fn into_iter(self) -> <&Bound<'py, PySet> as IntoIterator>::IntoIter

Returns an iterator of values in this set.

§Panics

If PyO3 detects that the set is mutated during iteration, it will panic.

§

type Item = Bound<'py, PyAny>

The type of the elements being iterated over.
§

type IntoIter = BoundSetIterator<'py>

Which kind of iterator are we turning this into?
§

impl<'py> IntoIterator for &Bound<'py, PyTuple>

§

type Item = Bound<'py, PyAny>

The type of the elements being iterated over.
§

type IntoIter = BoundTupleIterator<'py>

Which kind of iterator are we turning this into?
§

fn into_iter(self) -> <&Bound<'py, PyTuple> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
§

impl<'py> IntoIterator for Bound<'py, PyDict>

§

type Item = (Bound<'py, PyAny>, Bound<'py, PyAny>)

The type of the elements being iterated over.
§

type IntoIter = BoundDictIterator<'py>

Which kind of iterator are we turning this into?
§

fn into_iter(self) -> <Bound<'py, PyDict> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
§

impl<'py> IntoIterator for Bound<'py, PyFrozenSet>

§

fn into_iter(self) -> <Bound<'py, PyFrozenSet> as IntoIterator>::IntoIter

Returns an iterator of values in this set.

§

type Item = Bound<'py, PyAny>

The type of the elements being iterated over.
§

type IntoIter = BoundFrozenSetIterator<'py>

Which kind of iterator are we turning this into?
§

impl<'py> IntoIterator for Bound<'py, PyList>

§

type Item = Bound<'py, PyAny>

The type of the elements being iterated over.
§

type IntoIter = BoundListIterator<'py>

Which kind of iterator are we turning this into?
§

fn into_iter(self) -> <Bound<'py, PyList> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
§

impl<'py> IntoIterator for Bound<'py, PySet>

§

fn into_iter(self) -> <Bound<'py, PySet> as IntoIterator>::IntoIter

Returns an iterator of values in this set.

§Panics

If PyO3 detects that the set is mutated during iteration, it will panic.

§

type Item = Bound<'py, PyAny>

The type of the elements being iterated over.
§

type IntoIter = BoundSetIterator<'py>

Which kind of iterator are we turning this into?
§

impl<'py> IntoIterator for Bound<'py, PyTuple>

§

type Item = Bound<'py, PyAny>

The type of the elements being iterated over.
§

type IntoIter = BoundTupleIterator<'py>

Which kind of iterator are we turning this into?
§

fn into_iter(self) -> <Bound<'py, PyTuple> as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
§

impl<T> IntoPy<Py<PyAny>> for &Bound<'_, T>

§

fn into_py(self, py: Python<'_>) -> Py<PyAny>

👎Deprecated since 0.23.0: IntoPy is going to be replaced by IntoPyObject. See the migration guide (https://pyo3.rs/v0.23.0/migration) for more information.

Converts &Bound instance -> PyObject, increasing the reference count.

§

impl<T> IntoPy<Py<PyAny>> for Bound<'_, T>

§

fn into_py(self, _py: Python<'_>) -> Py<PyAny>

👎Deprecated since 0.23.0: IntoPy is going to be replaced by IntoPyObject. See the migration guide (https://pyo3.rs/v0.23.0/migration) for more information.

Converts a Bound instance to PyObject.

§

impl IntoPy<Py<PyString>> for &Bound<'_, PyString>

§

fn into_py(self, _py: Python<'_>) -> Py<PyString>

👎Deprecated since 0.23.0: IntoPy is going to be replaced by IntoPyObject. See the migration guide (https://pyo3.rs/v0.23.0/migration) for more information.
Performs the conversion.
§

impl IntoPy<Py<PyString>> for Bound<'_, PyString>

§

fn into_py(self, _py: Python<'_>) -> Py<PyString>

👎Deprecated since 0.23.0: IntoPy is going to be replaced by IntoPyObject. See the migration guide (https://pyo3.rs/v0.23.0/migration) for more information.
Performs the conversion.
§

impl IntoPy<Py<PyTuple>> for &Bound<'_, PyTuple>

§

fn into_py(self, _: Python<'_>) -> Py<PyTuple>

👎Deprecated since 0.23.0: IntoPy is going to be replaced by IntoPyObject. See the migration guide (https://pyo3.rs/v0.23.0/migration) for more information.
Performs the conversion.
§

impl IntoPy<Py<PyTuple>> for Bound<'_, PyTuple>

§

fn into_py(self, _: Python<'_>) -> Py<PyTuple>

👎Deprecated since 0.23.0: IntoPy is going to be replaced by IntoPyObject. See the migration guide (https://pyo3.rs/v0.23.0/migration) for more information.
Performs the conversion.
§

impl<'a, 'py, T> IntoPyObject<'py> for &'a Bound<'py, T>

§

type Target = T

The Python output type
§

type Output = Borrowed<'a, 'py, <&'a Bound<'py, T> as IntoPyObject<'py>>::Target>

The smart pointer type to use. Read more
§

type Error = Infallible

The type returned in the event of a conversion 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>

Performs the conversion.
§

impl<'py, T> IntoPyObject<'py> for Bound<'py, T>

§

type Target = T

The Python output type
§

type Output = Bound<'py, <Bound<'py, T> as IntoPyObject<'py>>::Target>

The smart pointer type to use. Read more
§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn into_pyobject( self, _py: Python<'py>, ) -> Result<<Bound<'py, T> as IntoPyObject<'py>>::Output, <Bound<'py, T> as IntoPyObject<'py>>::Error>

Performs the conversion.
§

impl<'py> Iterator for Bound<'py, PyIterator>

§

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.

§

type Item = Result<Bound<'py, PyAny>, PyErr>

The type of the elements being iterated over.
§

fn size_hint(&self) -> (usize, Option<usize>)

Returns the bounds on the remaining length of the iterator. Read more
Source§

fn next_chunk<const N: usize>( &mut self, ) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>
where Self: Sized,

🔬This is a nightly-only experimental API. (iter_next_chunk)
Advances the iterator and returns an array containing the next N values. Read more
1.0.0 · Source§

fn count(self) -> usize
where Self: Sized,

Consumes the iterator, counting the number of iterations and returning it. Read more
1.0.0 · Source§

fn last(self) -> Option<Self::Item>
where Self: Sized,

Consumes the iterator, returning the last element. Read more
Source§

fn advance_by(&mut self, n: usize) -> Result<(), NonZero<usize>>

🔬This is a nightly-only experimental API. (iter_advance_by)
Advances the iterator by n elements. Read more
1.0.0 · Source§

fn nth(&mut self, n: usize) -> Option<Self::Item>

Returns the nth element of the iterator. Read more
1.28.0 · Source§

fn step_by(self, step: usize) -> StepBy<Self>
where Self: Sized,

Creates an iterator starting at the same point, but stepping by the given amount at each iteration. Read more
1.0.0 · Source§

fn chain<U>(self, other: U) -> Chain<Self, <U as IntoIterator>::IntoIter>
where Self: Sized, U: IntoIterator<Item = Self::Item>,

Takes two iterators and creates a new iterator over both in sequence. Read more
1.0.0 · Source§

fn zip<U>(self, other: U) -> Zip<Self, <U as IntoIterator>::IntoIter>
where Self: Sized, U: IntoIterator,

‘Zips up’ two iterators into a single iterator of pairs. Read more
Source§

fn intersperse(self, separator: Self::Item) -> Intersperse<Self>
where Self: Sized, Self::Item: Clone,

🔬This is a nightly-only experimental API. (iter_intersperse)
Creates a new iterator which places a copy of separator between adjacent items of the original iterator. Read more
Source§

fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G>
where Self: Sized, G: FnMut() -> Self::Item,

🔬This is a nightly-only experimental API. (iter_intersperse)
Creates a new iterator which places an item generated by separator between adjacent items of the original iterator. Read more
1.0.0 · Source§

fn map<B, F>(self, f: F) -> Map<Self, F>
where Self: Sized, F: FnMut(Self::Item) -> B,

Takes a closure and creates an iterator which calls that closure on each element. Read more
1.21.0 · Source§

fn for_each<F>(self, f: F)
where Self: Sized, F: FnMut(Self::Item),

Calls a closure on each element of an iterator. Read more
1.0.0 · Source§

fn filter<P>(self, predicate: P) -> Filter<Self, P>
where Self: Sized, P: FnMut(&Self::Item) -> bool,

Creates an iterator which uses a closure to determine if an element should be yielded. Read more
1.0.0 · Source§

fn filter_map<B, F>(self, f: F) -> FilterMap<Self, F>
where Self: Sized, F: FnMut(Self::Item) -> Option<B>,

Creates an iterator that both filters and maps. Read more
1.0.0 · Source§

fn enumerate(self) -> Enumerate<Self>
where Self: Sized,

Creates an iterator which gives the current iteration count as well as the next value. Read more
1.0.0 · Source§

fn peekable(self) -> Peekable<Self>
where Self: Sized,

Creates an iterator which can use the peek and peek_mut methods to look at the next element of the iterator without consuming it. See their documentation for more information. Read more
1.0.0 · Source§

fn skip_while<P>(self, predicate: P) -> SkipWhile<Self, P>
where Self: Sized, P: FnMut(&Self::Item) -> bool,

Creates an iterator that skips elements based on a predicate. Read more
1.0.0 · Source§

fn take_while<P>(self, predicate: P) -> TakeWhile<Self, P>
where Self: Sized, P: FnMut(&Self::Item) -> bool,

Creates an iterator that yields elements based on a predicate. Read more
1.57.0 · Source§

fn map_while<B, P>(self, predicate: P) -> MapWhile<Self, P>
where Self: Sized, P: FnMut(Self::Item) -> Option<B>,

Creates an iterator that both yields elements based on a predicate and maps. Read more
1.0.0 · Source§

fn skip(self, n: usize) -> Skip<Self>
where Self: Sized,

Creates an iterator that skips the first n elements. Read more
1.0.0 · Source§

fn take(self, n: usize) -> Take<Self>
where Self: Sized,

Creates an iterator that yields the first n elements, or fewer if the underlying iterator ends sooner. Read more
1.0.0 · Source§

fn scan<St, B, F>(self, initial_state: St, f: F) -> Scan<Self, St, F>
where Self: Sized, F: FnMut(&mut St, Self::Item) -> Option<B>,

An iterator adapter which, like fold, holds internal state, but unlike fold, produces a new iterator. Read more
1.0.0 · Source§

fn flat_map<U, F>(self, f: F) -> FlatMap<Self, U, F>
where Self: Sized, U: IntoIterator, F: FnMut(Self::Item) -> U,

Creates an iterator that works like map, but flattens nested structure. Read more
1.29.0 · Source§

fn flatten(self) -> Flatten<Self>
where Self: Sized, Self::Item: IntoIterator,

Creates an iterator that flattens nested structure. Read more
Source§

fn map_windows<F, R, const N: usize>(self, f: F) -> MapWindows<Self, F, N>
where Self: Sized, F: FnMut(&[Self::Item; N]) -> R,

🔬This is a nightly-only experimental API. (iter_map_windows)
Calls the given function 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 more
1.0.0 · Source§

fn fuse(self) -> Fuse<Self>
where Self: Sized,

Creates an iterator which ends after the first None. Read more
1.0.0 · Source§

fn inspect<F>(self, f: F) -> Inspect<Self, F>
where Self: Sized, F: FnMut(&Self::Item),

Does something with each element of an iterator, passing the value on. Read more
1.0.0 · Source§

fn by_ref(&mut self) -> &mut Self
where Self: Sized,

Borrows an iterator, rather than consuming it. Read more
1.0.0 · Source§

fn collect<B>(self) -> B
where B: FromIterator<Self::Item>, Self: Sized,

Transforms an iterator into a collection. Read more
Source§

fn try_collect<B>( &mut self, ) -> <<Self::Item as Try>::Residual as Residual<B>>::TryType
where Self: Sized, Self::Item: Try, <Self::Item as Try>::Residual: Residual<B>, B: FromIterator<<Self::Item as Try>::Output>,

🔬This is a nightly-only experimental API. (iterator_try_collect)
Fallibly transforms an iterator into a collection, short circuiting if a failure is encountered. Read more
Source§

fn collect_into<E>(self, collection: &mut E) -> &mut E
where E: Extend<Self::Item>, Self: Sized,

🔬This is a nightly-only experimental API. (iter_collect_into)
Collects all the items from an iterator into a collection. Read more
1.0.0 · Source§

fn partition<B, F>(self, f: F) -> (B, B)
where Self: Sized, B: Default + Extend<Self::Item>, F: FnMut(&Self::Item) -> bool,

Consumes an iterator, creating two collections from it. Read more
Source§

fn partition_in_place<'a, T, P>(self, predicate: P) -> usize
where T: 'a, Self: Sized + DoubleEndedIterator<Item = &'a mut T>, P: FnMut(&T) -> bool,

🔬This is a nightly-only experimental API. (iter_partition_in_place)
Reorders the elements of this iterator in-place according to the given predicate, such that all those that return true precede all those that return false. Returns the number of true elements found. Read more
Source§

fn is_partitioned<P>(self, predicate: P) -> bool
where Self: Sized, P: FnMut(Self::Item) -> bool,

🔬This is a nightly-only experimental API. (iter_is_partitioned)
Checks if the elements of this iterator are partitioned according to the given predicate, such that all those that return true precede all those that return false. Read more
1.27.0 · Source§

fn try_fold<B, F, R>(&mut self, init: B, f: F) -> R
where Self: Sized, F: FnMut(B, Self::Item) -> R, R: Try<Output = B>,

An iterator method that applies a function as long as it returns successfully, producing a single, final value. Read more
1.27.0 · Source§

fn try_for_each<F, R>(&mut self, f: F) -> R
where Self: Sized, F: FnMut(Self::Item) -> R, R: Try<Output = ()>,

An iterator method that applies a fallible function to each item in the iterator, stopping at the first error and returning that error. Read more
1.0.0 · Source§

fn fold<B, F>(self, init: B, f: F) -> B
where Self: Sized, F: FnMut(B, Self::Item) -> B,

Folds every element into an accumulator by applying an operation, returning the final result. Read more
1.51.0 · Source§

fn reduce<F>(self, f: F) -> Option<Self::Item>
where Self: Sized, F: FnMut(Self::Item, Self::Item) -> Self::Item,

Reduces the elements to a single one, by repeatedly applying a reducing operation. Read more
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
where Self: Sized, R: Try<Output = Self::Item>, <R as Try>::Residual: Residual<Option<Self::Item>>,

🔬This is a nightly-only experimental API. (iterator_try_reduce)
Reduces the elements to a single one by repeatedly applying a reducing operation. If the closure returns a failure, the failure is propagated back to the caller immediately. Read more
1.0.0 · Source§

fn all<F>(&mut self, f: F) -> bool
where Self: Sized, F: FnMut(Self::Item) -> bool,

Tests if every element of the iterator matches a predicate. Read more
1.0.0 · Source§

fn any<F>(&mut self, f: F) -> bool
where Self: Sized, F: FnMut(Self::Item) -> bool,

Tests if any element of the iterator matches a predicate. Read more
1.0.0 · Source§

fn find<P>(&mut self, predicate: P) -> Option<Self::Item>
where Self: Sized, P: FnMut(&Self::Item) -> bool,

Searches for an element of an iterator that satisfies a predicate. Read more
1.30.0 · Source§

fn find_map<B, F>(&mut self, f: F) -> Option<B>
where Self: Sized, F: FnMut(Self::Item) -> Option<B>,

Applies function to the elements of iterator and returns the first non-none result. Read more
Source§

fn try_find<R>( &mut self, f: impl FnMut(&Self::Item) -> R, ) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryType
where Self: Sized, R: Try<Output = bool>, <R as Try>::Residual: Residual<Option<Self::Item>>,

🔬This is a nightly-only experimental API. (try_find)
Applies function to the elements of iterator and returns the first true result or the first error. Read more
1.0.0 · Source§

fn position<P>(&mut self, predicate: P) -> Option<usize>
where Self: Sized, P: FnMut(Self::Item) -> bool,

Searches for an element in an iterator, returning its index. Read more
1.0.0 · Source§

fn rposition<P>(&mut self, predicate: P) -> Option<usize>
where P: FnMut(Self::Item) -> bool, Self: Sized + ExactSizeIterator + DoubleEndedIterator,

Searches for an element in an iterator from the right, returning its index. Read more
1.0.0 · Source§

fn max(self) -> Option<Self::Item>
where Self: Sized, Self::Item: Ord,

Returns the maximum element of an iterator. Read more
1.0.0 · Source§

fn min(self) -> Option<Self::Item>
where Self: Sized, Self::Item: Ord,

Returns the minimum element of an iterator. Read more
1.6.0 · Source§

fn max_by_key<B, F>(self, f: F) -> Option<Self::Item>
where B: Ord, Self: Sized, F: FnMut(&Self::Item) -> B,

Returns the element that gives the maximum value from the specified function. Read more
1.15.0 · Source§

fn max_by<F>(self, compare: F) -> Option<Self::Item>
where Self: Sized, F: FnMut(&Self::Item, &Self::Item) -> Ordering,

Returns the element that gives the maximum value with respect to the specified comparison function. Read more
1.6.0 · Source§

fn min_by_key<B, F>(self, f: F) -> Option<Self::Item>
where B: Ord, Self: Sized, F: FnMut(&Self::Item) -> B,

Returns the element that gives the minimum value from the specified function. Read more
1.15.0 · Source§

fn min_by<F>(self, compare: F) -> Option<Self::Item>
where Self: Sized, F: FnMut(&Self::Item, &Self::Item) -> Ordering,

Returns the element that gives the minimum value with respect to the specified comparison function. Read more
1.0.0 · Source§

fn rev(self) -> Rev<Self>
where Self: Sized + DoubleEndedIterator,

Reverses an iterator’s direction. Read more
1.0.0 · Source§

fn unzip<A, B, FromA, FromB>(self) -> (FromA, FromB)
where FromA: Default + Extend<A>, FromB: Default + Extend<B>, Self: Sized + Iterator<Item = (A, B)>,

Converts an iterator of pairs into a pair of containers. Read more
1.36.0 · Source§

fn copied<'a, T>(self) -> Copied<Self>
where T: 'a + Copy, Self: Sized + Iterator<Item = &'a T>,

Creates an iterator which copies all of its elements. Read more
1.0.0 · Source§

fn cloned<'a, T>(self) -> Cloned<Self>
where T: 'a + Clone, Self: Sized + Iterator<Item = &'a T>,

Creates an iterator which clones all of its elements. Read more
1.0.0 · Source§

fn cycle(self) -> Cycle<Self>
where Self: Sized + Clone,

Repeats an iterator endlessly. Read more
Source§

fn array_chunks<const N: usize>(self) -> ArrayChunks<Self, N>
where Self: Sized,

🔬This is a nightly-only experimental API. (iter_array_chunks)
Returns an iterator over N elements of the iterator at a time. Read more
1.11.0 · Source§

fn sum<S>(self) -> S
where Self: Sized, S: Sum<Self::Item>,

Sums the elements of an iterator. Read more
1.11.0 · Source§

fn product<P>(self) -> P
where Self: Sized, P: Product<Self::Item>,

Iterates over the entire iterator, multiplying all the elements Read more
1.5.0 · Source§

fn cmp<I>(self, other: I) -> Ordering
where I: IntoIterator<Item = Self::Item>, Self::Item: Ord, Self: Sized,

Lexicographically compares the elements of this Iterator with those of another. Read more
Source§

fn cmp_by<I, F>(self, other: I, cmp: F) -> Ordering
where Self: Sized, I: IntoIterator, F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Ordering,

🔬This is a nightly-only experimental API. (iter_order_by)
Lexicographically compares the elements of this Iterator with those of another with respect to the specified comparison function. Read more
1.5.0 · Source§

fn partial_cmp<I>(self, other: I) -> Option<Ordering>
where I: IntoIterator, Self::Item: PartialOrd<<I as IntoIterator>::Item>, Self: Sized,

Lexicographically compares the 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 more
Source§

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>,

🔬This is a nightly-only experimental API. (iter_order_by)
Lexicographically compares the elements of this Iterator with those of another with respect to the specified comparison function. Read more
1.5.0 · Source§

fn eq<I>(self, other: I) -> bool
where I: IntoIterator, Self::Item: PartialEq<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are equal to those of another. Read more
Source§

fn eq_by<I, F>(self, other: I, eq: F) -> bool
where Self: Sized, I: IntoIterator, F: FnMut(Self::Item, <I as IntoIterator>::Item) -> bool,

🔬This is a nightly-only experimental API. (iter_order_by)
Determines if the elements of this Iterator are equal to those of another with respect to the specified equality function. Read more
1.5.0 · Source§

fn ne<I>(self, other: I) -> bool
where I: IntoIterator, Self::Item: PartialEq<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are not equal to those of another. Read more
1.5.0 · Source§

fn lt<I>(self, other: I) -> bool
where I: IntoIterator, Self::Item: PartialOrd<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are lexicographically less than those of another. Read more
1.5.0 · Source§

fn le<I>(self, other: I) -> bool
where I: IntoIterator, Self::Item: PartialOrd<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are lexicographically less or equal to those of another. Read more
1.5.0 · Source§

fn gt<I>(self, other: I) -> bool
where I: IntoIterator, Self::Item: PartialOrd<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are lexicographically greater than those of another. Read more
1.5.0 · Source§

fn ge<I>(self, other: I) -> bool
where I: IntoIterator, Self::Item: PartialOrd<<I as IntoIterator>::Item>, Self: Sized,

Determines if the elements of this Iterator are lexicographically greater than or equal to those of another. Read more
1.82.0 · Source§

fn is_sorted(self) -> bool
where Self: Sized, Self::Item: PartialOrd,

Checks if the elements of this iterator are sorted. Read more
1.82.0 · Source§

fn is_sorted_by<F>(self, compare: F) -> bool
where Self: Sized, F: FnMut(&Self::Item, &Self::Item) -> bool,

Checks if the elements of this iterator are sorted using the given comparator function. Read more
1.82.0 · Source§

fn is_sorted_by_key<F, K>(self, f: F) -> bool
where Self: Sized, F: FnMut(Self::Item) -> K, K: PartialOrd,

Checks if the elements of this iterator are sorted using the given key extraction function. Read more
§

impl<'py> Mul<&Bound<'py, PyComplex>> for Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the * operator.
§

fn mul(self, other: &Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the * operation. Read more
§

impl<'py> Mul<Bound<'py, PyComplex>> for &Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the * operator.
§

fn mul(self, other: Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the * operation. Read more
§

impl<'py> Mul for &Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the * operator.
§

fn mul(self, other: &Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the * operation. Read more
§

impl<'py> Mul for Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the * operator.
§

fn mul(self, other: Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the * operation. Read more
§

impl<'py> Neg for &Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the - operator.
§

fn neg(self) -> Bound<'py, PyComplex>

Performs the unary - operation. Read more
§

impl<'py> Neg for Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the - operator.
§

fn neg(self) -> Bound<'py, PyComplex>

Performs the unary - operation. Read more
§

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.

§

fn eq(&self, other: &&[u8]) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<&Bound<'_, PyBool>> for bool

Compare bool with &Bound<PyBool>

§

fn eq(&self, other: &&Bound<'_, PyBool>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

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.

§

fn eq(&self, other: &&Bound<'_, PyBytes>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<&Bound<'_, PyFloat>> for f32

§

fn eq(&self, other: &&Bound<'_, PyFloat>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<&Bound<'_, PyFloat>> for f64

§

fn eq(&self, other: &&Bound<'_, PyFloat>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

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.

§

fn eq(&self, other: &&Bound<'_, PyString>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<&bool> for Bound<'_, PyBool>

Compare Bound<PyBool> with &bool.

§

fn eq(&self, other: &&bool) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<&f32> for Bound<'_, PyFloat>

§

fn eq(&self, other: &&f32) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<&f64> for Bound<'_, PyFloat>

§

fn eq(&self, other: &&f64) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

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.

§

fn eq(&self, other: &&str) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

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.

§

fn eq(&self, other: &[u8]) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

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.

§

fn eq(&self, other: &[u8]) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyBool>> for &bool

Compare &bool with Bound<PyBool>

§

fn eq(&self, other: &Bound<'_, PyBool>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyBool>> for bool

Compare bool with Bound<PyBool>

§

fn eq(&self, other: &Bound<'_, PyBool>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

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.

§

fn eq(&self, other: &Bound<'_, PyBytes>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

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.

§

fn eq(&self, other: &Bound<'_, PyBytes>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyFloat>> for &f32

§

fn eq(&self, other: &Bound<'_, PyFloat>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyFloat>> for &f64

§

fn eq(&self, other: &Bound<'_, PyFloat>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyFloat>> for f32

§

fn eq(&self, other: &Bound<'_, PyFloat>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyFloat>> for f64

§

fn eq(&self, other: &Bound<'_, PyFloat>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for i128

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for i16

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for i32

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for i64

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for i8

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for isize

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for u128

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for u16

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for u32

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for u64

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for u8

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<Bound<'_, PyInt>> for usize

§

fn eq(&self, other: &Bound<'_, PyInt>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

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.

§

fn eq(&self, other: &Bound<'_, PyString>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

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.

§

fn eq(&self, other: &Bound<'_, PyString>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<bool> for &Bound<'_, PyBool>

Compare &Bound<PyBool> with bool.

§

fn eq(&self, other: &bool) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<bool> for Bound<'_, PyBool>

Compare Bound<PyBool> with bool.

§

fn eq(&self, other: &bool) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<f32> for &Bound<'_, PyFloat>

§

fn eq(&self, other: &f32) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<f32> for Bound<'_, PyFloat>

§

fn eq(&self, other: &f32) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<f64> for &Bound<'_, PyFloat>

§

fn eq(&self, other: &f64) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<f64> for Bound<'_, PyFloat>

§

fn eq(&self, other: &f64) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<i128> for Bound<'_, PyInt>

§

fn eq(&self, other: &i128) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<i16> for Bound<'_, PyInt>

§

fn eq(&self, other: &i16) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<i32> for Bound<'_, PyInt>

§

fn eq(&self, other: &i32) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<i64> for Bound<'_, PyInt>

§

fn eq(&self, other: &i64) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<i8> for Bound<'_, PyInt>

§

fn eq(&self, other: &i8) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<isize> for Bound<'_, PyInt>

§

fn eq(&self, other: &isize) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

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.

§

fn eq(&self, other: &str) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

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.

§

fn eq(&self, other: &str) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<u128> for Bound<'_, PyInt>

§

fn eq(&self, other: &u128) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<u16> for Bound<'_, PyInt>

§

fn eq(&self, other: &u16) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<u32> for Bound<'_, PyInt>

§

fn eq(&self, other: &u32) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<u64> for Bound<'_, PyInt>

§

fn eq(&self, other: &u64) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<u8> for Bound<'_, PyInt>

§

fn eq(&self, other: &u8) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl PartialEq<usize> for Bound<'_, PyInt>

§

fn eq(&self, other: &usize) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl<'py> PyAnyMethods<'py> for Bound<'py, PyAny>

§

fn add<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self + other.

§

fn sub<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self - other.

§

fn mul<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self * other.

§

fn matmul<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self @ other.

§

fn div<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self / other.

§

fn floor_div<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self // other.

§

fn rem<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self % other.

§

fn lshift<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self << other.

§

fn rshift<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self >> other.

§

fn bitand<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self & other.

§

fn bitor<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self | other.

§

fn bitxor<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes self ^ other.

§

fn divmod<O>(&self, other: O) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Computes divmod(self, other).

§

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.

§

fn is<T>(&self, other: &T) -> bool
where T: AsPyPointer,

Returns whether self and other point to the same object. To compare the equality of two objects (the == operator), use eq. Read more
§

fn hasattr<N>(&self, attr_name: N) -> Result<bool, PyErr>
where N: IntoPyObject<'py, Target = PyString>,

Determines whether this object has the given attribute. Read more
§

fn getattr<N>(&self, attr_name: N) -> Result<Bound<'py, PyAny>, PyErr>
where N: IntoPyObject<'py, Target = PyString>,

Retrieves an attribute value. Read more
§

fn setattr<N, V>(&self, attr_name: N, value: V) -> Result<(), PyErr>
where N: IntoPyObject<'py, Target = PyString>, V: IntoPyObject<'py>,

Sets an attribute value. Read more
§

fn delattr<N>(&self, attr_name: N) -> Result<(), PyErr>
where N: IntoPyObject<'py, Target = PyString>,

Deletes an attribute. Read more
§

fn compare<O>(&self, other: O) -> Result<Ordering, PyErr>
where O: IntoPyObject<'py>,

Returns an Ordering between self and other. Read more
§

fn rich_compare<O>( &self, other: O, compare_op: CompareOp, ) -> Result<Bound<'py, PyAny>, PyErr>
where O: IntoPyObject<'py>,

Tests whether two Python objects obey a given CompareOp. Read more
§

fn neg(&self) -> Result<Bound<'py, PyAny>, PyErr>

Computes the negative of self. Read more
§

fn pos(&self) -> Result<Bound<'py, PyAny>, PyErr>

Computes the positive of self. Read more
§

fn abs(&self) -> Result<Bound<'py, PyAny>, PyErr>

Computes the absolute of self. Read more
§

fn bitnot(&self) -> Result<Bound<'py, PyAny>, PyErr>

Computes ~self.
§

fn lt<O>(&self, other: O) -> Result<bool, PyErr>
where O: IntoPyObject<'py>,

Tests whether this object is less than another. Read more
§

fn le<O>(&self, other: O) -> Result<bool, PyErr>
where O: IntoPyObject<'py>,

Tests whether this object is less than or equal to another. Read more
§

fn eq<O>(&self, other: O) -> Result<bool, PyErr>
where O: IntoPyObject<'py>,

Tests whether this object is equal to another. Read more
§

fn ne<O>(&self, other: O) -> Result<bool, PyErr>
where O: IntoPyObject<'py>,

Tests whether this object is not equal to another. Read more
§

fn gt<O>(&self, other: O) -> Result<bool, PyErr>
where O: IntoPyObject<'py>,

Tests whether this object is greater than another. Read more
§

fn ge<O>(&self, other: O) -> Result<bool, PyErr>
where O: IntoPyObject<'py>,

Tests whether this object is greater than or equal to another. Read more
§

fn is_callable(&self) -> bool

Determines whether this object appears callable. Read more
§

fn call<A>( &self, args: A, kwargs: Option<&Bound<'py, PyDict>>, ) -> Result<Bound<'py, PyAny>, PyErr>
where A: IntoPyObject<'py, Target = PyTuple>,

Calls the object. Read more
§

fn call0(&self) -> Result<Bound<'py, PyAny>, PyErr>

Calls the object without arguments. Read more
§

fn call1<A>(&self, args: A) -> Result<Bound<'py, PyAny>, PyErr>
where A: IntoPyObject<'py, Target = PyTuple>,

Calls the object with only positional arguments. Read more
§

fn call_method<N, A>( &self, name: N, args: A, kwargs: Option<&Bound<'py, PyDict>>, ) -> Result<Bound<'py, PyAny>, PyErr>
where N: IntoPyObject<'py, Target = PyString>, A: IntoPyObject<'py, Target = PyTuple>,

Calls a method on the object. Read more
§

fn call_method0<N>(&self, name: N) -> Result<Bound<'py, PyAny>, PyErr>
where N: IntoPyObject<'py, Target = PyString>,

Calls a method on the object without arguments. Read more
§

fn call_method1<N, A>( &self, name: N, args: A, ) -> Result<Bound<'py, PyAny>, PyErr>
where N: IntoPyObject<'py, Target = PyString>, A: IntoPyObject<'py, Target = PyTuple>,

Calls a method on the object with only positional arguments. Read more
§

fn is_truthy(&self) -> Result<bool, PyErr>

Returns whether the object is considered to be true. Read more
§

fn is_none(&self) -> bool

Returns whether the object is considered to be None. Read more
§

fn is_ellipsis(&self) -> bool

👎Deprecated since 0.23.0: use .is(py.Ellipsis()) instead
Returns whether the object is Ellipsis, e.g. .... Read more
§

fn is_empty(&self) -> Result<bool, PyErr>

Returns true if the sequence or mapping has a length of 0. Read more
§

fn get_item<K>(&self, key: K) -> Result<Bound<'py, PyAny>, PyErr>
where K: IntoPyObject<'py>,

Gets an item from the collection. Read more
§

fn set_item<K, V>(&self, key: K, value: V) -> Result<(), PyErr>
where K: IntoPyObject<'py>, V: IntoPyObject<'py>,

Sets a collection item value. Read more
§

fn del_item<K>(&self, key: K) -> Result<(), PyErr>
where K: IntoPyObject<'py>,

Deletes an item from the collection. Read more
§

fn try_iter(&self) -> Result<Bound<'py, PyIterator>, PyErr>

Takes an object and returns an iterator for it. Returns an error if the object is not iterable. Read more
§

fn iter(&self) -> Result<Bound<'py, PyIterator>, PyErr>

👎Deprecated since 0.23.0: use try_iter instead
Takes an object and returns an iterator for it. Read more
§

fn get_type(&self) -> Bound<'py, PyType>

Returns the Python type object for this object’s type.
§

fn get_type_ptr(&self) -> *mut PyTypeObject

Returns the Python type pointer for this object.
§

fn downcast<T>(&self) -> Result<&Bound<'py, T>, DowncastError<'_, 'py>>
where T: PyTypeCheck,

Downcast this PyAny to a concrete Python type or pyclass. Read more
§

fn downcast_into<T>(self) -> Result<Bound<'py, T>, DowncastIntoError<'py>>
where T: PyTypeCheck,

Like downcast but takes ownership of self. Read more
§

fn downcast_exact<T>(&self) -> Result<&Bound<'py, T>, DowncastError<'_, 'py>>
where T: PyTypeInfo,

Downcast this PyAny to a concrete Python type or pyclass (but not a subclass of it). Read more
§

fn downcast_into_exact<T>(self) -> Result<Bound<'py, T>, DowncastIntoError<'py>>
where T: PyTypeInfo,

Like downcast_exact but takes ownership of self.
§

unsafe fn downcast_unchecked<T>(&self) -> &Bound<'py, T>

Converts this PyAny to a concrete Python type without checking validity. Read more
§

unsafe fn downcast_into_unchecked<T>(self) -> Bound<'py, T>

Like downcast_unchecked but takes ownership of self. Read more
§

fn extract<'a, T>(&'a self) -> Result<T, PyErr>
where T: FromPyObjectBound<'a, 'py>,

Extracts some type from the Python object. Read more
§

fn get_refcnt(&self) -> isize

Returns the reference count for the Python object.
§

fn repr(&self) -> Result<Bound<'py, PyString>, PyErr>

Computes the “repr” representation of self. Read more
§

fn str(&self) -> Result<Bound<'py, PyString>, PyErr>

Computes the “str” representation of self. Read more
§

fn hash(&self) -> Result<isize, PyErr>

Retrieves the hash code of self. Read more
§

fn len(&self) -> Result<usize, PyErr>

Returns the length of the sequence or mapping. Read more
§

fn dir(&self) -> Result<Bound<'py, PyList>, PyErr>

Returns the list of attributes of this object. Read more
§

fn is_instance(&self, ty: &Bound<'py, PyAny>) -> Result<bool, PyErr>

Checks whether this object is an instance of type ty. Read more
§

fn is_exact_instance(&self, ty: &Bound<'py, PyAny>) -> bool

Checks whether this object is an instance of exactly type ty (not a subclass). Read more
§

fn is_instance_of<T>(&self) -> bool
where T: PyTypeInfo,

Checks whether this object is an instance of type T. Read more
§

fn is_exact_instance_of<T>(&self) -> bool
where T: PyTypeInfo,

Checks whether this object is an instance of exactly type T. Read more
§

fn contains<V>(&self, value: V) -> Result<bool, PyErr>
where V: IntoPyObject<'py>,

Determines if self contains value. Read more
§

fn py_super(&self) -> Result<Bound<'py, PySuper>, PyErr>

Return a proxy object that delegates method calls to a parent or sibling class of type. Read more
§

impl<'py> PyBoolMethods<'py> for Bound<'py, PyBool>

§

fn is_true(&self) -> bool

Gets whether this boolean is true.
§

impl<'py> PyByteArrayMethods<'py> for Bound<'py, PyByteArray>

§

fn len(&self) -> usize

Gets the length of the bytearray.
§

fn is_empty(&self) -> bool

Checks if the bytearray is empty.
§

fn data(&self) -> *mut u8

Gets the start of the buffer containing the contents of the bytearray. Read more
§

unsafe fn as_bytes(&self) -> &[u8]

Extracts a slice of the ByteArray’s entire buffer. Read more
§

unsafe fn as_bytes_mut(&self) -> &mut [u8]

Extracts a mutable slice of the ByteArray’s entire buffer. Read more
§

fn to_vec(&self) -> Vec<u8>

Copies the contents of the bytearray to a Rust vector. Read more
§

fn resize(&self, len: usize) -> Result<(), PyErr>

Resizes the bytearray object to the new length len. Read more
§

impl<'py> PyBytesMethods<'py> for Bound<'py, PyBytes>

§

fn as_bytes(&self) -> &[u8]

Gets the Python string as a byte slice.
§

impl<'py> PyCapsuleMethods<'py> for Bound<'py, PyCapsule>

§

fn set_context(&self, context: *mut c_void) -> Result<(), PyErr>

Sets the context pointer in the capsule. Read more
§

fn context(&self) -> Result<*mut c_void, PyErr>

Gets the current context stored in the capsule. If there is no context, the pointer will be null. Read more
§

unsafe fn reference<T>(&self) -> &'py T

Obtains a reference to the value of this capsule. Read more
§

fn pointer(&self) -> *mut c_void

Gets the raw c_void pointer to the value in this capsule. Read more
§

fn is_valid(&self) -> bool

Checks if this is a valid capsule. Read more
§

fn name(&self) -> Result<Option<&'py CStr>, PyErr>

Retrieves the name of this capsule, if set. Read more
§

impl<'py> PyComplexMethods<'py> for Bound<'py, PyComplex>

§

fn real(&self) -> f64

Returns the real part of the complex number.
§

fn imag(&self) -> f64

Returns the imaginary part of the complex number.
§

fn abs(&self) -> f64

Returns |self|.
§

fn pow(&self, other: &Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Returns self raised to the power of other.
§

impl PyDateAccess for Bound<'_, PyDate>

§

fn get_year(&self) -> i32

Returns the year, as a positive int. Read more
§

fn get_month(&self) -> u8

Returns the month, as an int from 1 through 12. Read more
§

fn get_day(&self) -> u8

Returns the day, as an int from 1 through 31. Read more
§

impl PyDateAccess for Bound<'_, PyDateTime>

§

fn get_year(&self) -> i32

Returns the year, as a positive int. Read more
§

fn get_month(&self) -> u8

Returns the month, as an int from 1 through 12. Read more
§

fn get_day(&self) -> u8

Returns the day, as an int from 1 through 31. Read more
§

impl PyDeltaAccess for Bound<'_, PyDelta>

§

fn get_days(&self) -> i32

Returns the number of days, as an int from -999999999 to 999999999. Read more
§

fn get_seconds(&self) -> i32

Returns the number of seconds, as an int from 0 through 86399. Read more
§

fn get_microseconds(&self) -> i32

Returns the number of microseconds, as an int from 0 through 999999. Read more
§

impl<'py> PyDictMethods<'py> for Bound<'py, PyDict>

§

fn copy(&self) -> Result<Bound<'py, PyDict>, PyErr>

Returns a new dictionary that contains the same key-value pairs as self. Read more
§

fn clear(&self)

Empties an existing dictionary of all key-value pairs.
§

fn len(&self) -> usize

Return the number of items in the dictionary. Read more
§

fn is_empty(&self) -> bool

Checks if the dict is empty, i.e. len(self) == 0.
§

fn contains<K>(&self, key: K) -> Result<bool, PyErr>
where K: IntoPyObject<'py>,

Determines if the dictionary contains the specified key. Read more
§

fn get_item<K>(&self, key: K) -> Result<Option<Bound<'py, PyAny>>, PyErr>
where K: IntoPyObject<'py>,

Gets an item from the dictionary. Read more
§

fn set_item<K, V>(&self, key: K, value: V) -> Result<(), PyErr>
where K: IntoPyObject<'py>, V: IntoPyObject<'py>,

Sets an item value. Read more
§

fn del_item<K>(&self, key: K) -> Result<(), PyErr>
where K: IntoPyObject<'py>,

Deletes an item. Read more
§

fn keys(&self) -> Bound<'py, PyList>

Returns a list of dict keys. Read more
§

fn values(&self) -> Bound<'py, PyList>

Returns a list of dict values. Read more
§

fn items(&self) -> Bound<'py, PyList>

Returns a list of dict items. Read more
§

fn iter(&self) -> BoundDictIterator<'py>

Returns an iterator of (key, value) pairs in this dictionary. Read more
§

fn locked_for_each<F>(&self, f: F) -> Result<(), PyErr>
where F: Fn(Bound<'py, PyAny>, Bound<'py, PyAny>) -> Result<(), PyErr>,

Iterates over the contents of this dictionary while holding a critical section on the dict. This is useful when the GIL is disabled and the dictionary is shared between threads. It is not guaranteed that the dictionary will not be modified during iteration when the closure calls arbitrary Python code that releases the critical section held by the iterator. Otherwise, the dictionary will not be modified during iteration. Read more
§

fn as_mapping(&self) -> &Bound<'py, PyMapping>

Returns self cast as a PyMapping.
§

fn into_mapping(self) -> Bound<'py, PyMapping>

Returns self cast as a PyMapping.
§

fn update(&self, other: &Bound<'_, PyMapping>) -> Result<(), PyErr>

Update this dictionary with the key/value pairs from another. Read more
§

fn update_if_missing(&self, other: &Bound<'_, PyMapping>) -> Result<(), PyErr>

Add key/value pairs from another dictionary to this one only when they do not exist in this. Read more
§

impl<'py> PyFloatMethods<'py> for Bound<'py, PyFloat>

§

fn value(&self) -> f64

Gets the value of this float.
§

impl<'py> PyFrozenSetMethods<'py> for Bound<'py, PyFrozenSet>

§

fn len(&self) -> usize

Returns the number of items in the set. Read more
§

fn contains<K>(&self, key: K) -> Result<bool, PyErr>
where K: IntoPyObject<'py>,

Determines if the set contains the specified key. Read more
§

fn iter(&self) -> BoundFrozenSetIterator<'py>

Returns an iterator of values in this set.
§

fn is_empty(&self) -> bool

Checks if set is empty.
§

impl<'py> PyListMethods<'py> for Bound<'py, PyList>

§

fn len(&self) -> usize

Returns the length of the list.

§

fn is_empty(&self) -> bool

Checks if the list is empty.

§

fn as_sequence(&self) -> &Bound<'py, PySequence>

Returns self cast as a PySequence.

§

fn into_sequence(self) -> Bound<'py, PySequence>

Returns self cast as a PySequence.

§

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::with_gil(|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);
});
§

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.

§

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().

§

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.

§

fn del_item(&self, index: usize) -> Result<(), PyErr>

Deletes the indexth element of self.

This is equivalent to the Python statement del self[i].

§

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.

§

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].

§

fn append<I>(&self, item: I) -> Result<(), PyErr>
where I: IntoPyObject<'py>,

Appends an item to the list.

§

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.

§

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.

§

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).

§

fn iter(&self) -> BoundListIterator<'py>

Returns an iterator over this list’s items.

§

fn locked_for_each<F>(&self, closure: F) -> Result<(), PyErr>
where F: Fn(Bound<'py, PyAny>) -> Result<(), PyErr>,

Iterates over a list while holding a critical section, calling a closure on each item

§

fn sort(&self) -> Result<(), PyErr>

Sorts the list in-place. Equivalent to the Python expression l.sort().

§

fn reverse(&self) -> Result<(), PyErr>

Reverses the list in-place. Equivalent to the Python expression l.reverse().

§

fn to_tuple(&self) -> Bound<'py, PyTuple>

Return a new tuple containing the contents of the list; equivalent to the Python expression tuple(list).

This method is equivalent to self.as_sequence().to_tuple() and faster than PyTuple::new(py, this_list).

§

impl<'py> PyMappingMethods<'py> for Bound<'py, PyMapping>

§

fn len(&self) -> Result<usize, PyErr>

Returns the number of objects in the mapping. Read more
§

fn is_empty(&self) -> Result<bool, PyErr>

Returns whether the mapping is empty.
§

fn contains<K>(&self, key: K) -> Result<bool, PyErr>
where K: IntoPyObject<'py>,

Determines if the mapping contains the specified key. Read more
§

fn get_item<K>(&self, key: K) -> Result<Bound<'py, PyAny>, PyErr>
where K: IntoPyObject<'py>,

Gets the item in self with key key. Read more
§

fn set_item<K, V>(&self, key: K, value: V) -> Result<(), PyErr>
where K: IntoPyObject<'py>, V: IntoPyObject<'py>,

Sets the item in self with key key. Read more
§

fn del_item<K>(&self, key: K) -> Result<(), PyErr>
where K: IntoPyObject<'py>,

Deletes the item with key key. Read more
§

fn keys(&self) -> Result<Bound<'py, PyList>, PyErr>

Returns a list containing all keys in the mapping.
§

fn values(&self) -> Result<Bound<'py, PyList>, PyErr>

Returns a list containing all values in the mapping.
§

fn items(&self) -> Result<Bound<'py, PyList>, PyErr>

Returns a list of all (key, value) pairs in the mapping.
§

impl<'py, 'a> PyMappingProxyMethods<'py, 'a> for Bound<'py, PyMappingProxy>

§

fn is_empty(&self) -> Result<bool, PyErr>

Checks if the mappingproxy is empty, i.e. len(self) == 0.
§

fn keys(&self) -> Result<Bound<'py, PyList>, PyErr>

Returns a list containing all keys in the mapping.
§

fn values(&self) -> Result<Bound<'py, PyList>, PyErr>

Returns a list containing all values in the mapping.
§

fn items(&self) -> Result<Bound<'py, PyList>, PyErr>

Returns a list of tuples of all (key, value) pairs in the mapping.
§

fn as_mapping(&self) -> &Bound<'py, PyMapping>

Returns self cast as a PyMapping.
§

fn try_iter(&'a self) -> Result<BoundMappingProxyIterator<'py, 'a>, PyErr>

Takes an object and returns an iterator for it. Returns an error if the object is not iterable.
§

impl<'py> PyModuleMethods<'py> for Bound<'py, PyModule>

§

fn dict(&self) -> Bound<'py, PyDict>

Returns the module’s __dict__ attribute, which contains the module’s symbol table.
§

fn index(&self) -> Result<Bound<'py, PyList>, PyErr>

Returns the index (the __all__ attribute) of the module, creating one if needed. Read more
§

fn name(&self) -> Result<Bound<'py, PyString>, PyErr>

Returns the name (the __name__ attribute) of the module. Read more
§

fn filename(&self) -> Result<Bound<'py, PyString>, PyErr>

Returns the filename (the __file__ attribute) of the module. Read more
§

fn add<N, V>(&self, name: N, value: V) -> Result<(), PyErr>
where N: IntoPyObject<'py, Target = PyString>, V: IntoPyObject<'py>,

Adds an attribute to the module. Read more
§

fn add_class<T>(&self) -> Result<(), PyErr>
where T: PyClass,

Adds a new class to the module. Read more
§

fn add_wrapped<T>( &self, wrapper: &impl Fn(Python<'py>) -> T, ) -> Result<(), PyErr>
where T: IntoPyCallbackOutput<'py, Py<PyAny>>,

Adds a function or a (sub)module to a module, using the functions name as name. Read more
§

fn add_submodule(&self, module: &Bound<'_, PyModule>) -> Result<(), PyErr>

Adds a submodule to a module. Read more
§

fn add_function(&self, fun: Bound<'_, PyCFunction>) -> Result<(), PyErr>

Add a function to a module. Read more
§

fn gil_used(&self, gil_used: bool) -> Result<(), PyErr>

Declare whether or not this module supports running with the GIL disabled Read more
§

impl<'py> PySequenceMethods<'py> for Bound<'py, PySequence>

§

fn len(&self) -> Result<usize, PyErr>

Returns the number of objects in sequence. Read more
§

fn is_empty(&self) -> Result<bool, PyErr>

Returns whether the sequence is empty.
§

fn concat( &self, other: &Bound<'_, PySequence>, ) -> Result<Bound<'py, PySequence>, PyErr>

Returns the concatenation of self and other. Read more
§

fn repeat(&self, count: usize) -> Result<Bound<'py, PySequence>, PyErr>

Returns the result of repeating a sequence object count times. Read more
§

fn in_place_concat( &self, other: &Bound<'_, PySequence>, ) -> Result<Bound<'py, PySequence>, PyErr>

Concatenates self and other, in place if possible. Read more
§

fn in_place_repeat(&self, count: usize) -> Result<Bound<'py, PySequence>, PyErr>

Repeats the sequence object count times and updates self, if possible. Read more
§

fn get_item(&self, index: usize) -> Result<Bound<'py, PyAny>, PyErr>

Returns the indexth element of the Sequence. Read more
§

fn get_slice( &self, begin: usize, end: usize, ) -> Result<Bound<'py, PySequence>, PyErr>

Returns the slice of sequence object between begin and end. Read more
§

fn set_item<I>(&self, i: usize, item: I) -> Result<(), PyErr>
where I: IntoPyObject<'py>,

Assigns object item to the ith element of self. Read more
§

fn del_item(&self, i: usize) -> Result<(), PyErr>

Deletes the ith element of self. Read more
§

fn set_slice( &self, i1: usize, i2: usize, v: &Bound<'_, PyAny>, ) -> Result<(), PyErr>

Assigns the sequence v to the slice of self from i1 to i2. Read more
§

fn del_slice(&self, i1: usize, i2: usize) -> Result<(), PyErr>

Deletes the slice from i1 to i2 from self. Read more
§

fn count<V>(&self, value: V) -> Result<usize, PyErr>
where V: IntoPyObject<'py>,

Returns the number of occurrences of value in self, that is, return the number of keys for which self[key] == value.
§

fn contains<V>(&self, value: V) -> Result<bool, PyErr>
where V: IntoPyObject<'py>,

Determines if self contains value. Read more
§

fn index<V>(&self, value: V) -> Result<usize, PyErr>
where V: IntoPyObject<'py>,

Returns the first index i for which self[i] == value. Read more
§

fn to_list(&self) -> Result<Bound<'py, PyList>, PyErr>

Returns a fresh list based on the Sequence.
§

fn to_tuple(&self) -> Result<Bound<'py, PyTuple>, PyErr>

Returns a fresh tuple based on the Sequence.
§

impl<'py> PySetMethods<'py> for Bound<'py, PySet>

§

fn clear(&self)

Removes all elements from the set.
§

fn len(&self) -> usize

Returns the number of items in the set. Read more
§

fn contains<K>(&self, key: K) -> Result<bool, PyErr>
where K: IntoPyObject<'py>,

Determines if the set contains the specified key. Read more
§

fn discard<K>(&self, key: K) -> Result<bool, PyErr>
where K: IntoPyObject<'py>,

Removes the element from the set if it is present. Read more
§

fn add<K>(&self, key: K) -> Result<(), PyErr>
where K: IntoPyObject<'py>,

Adds an element to the set.
§

fn pop(&self) -> Option<Bound<'py, PyAny>>

Removes and returns an arbitrary element from the set.
§

fn iter(&self) -> BoundSetIterator<'py>

Returns an iterator of values in this set. Read more
§

fn is_empty(&self) -> bool

Checks if set is empty.
§

impl<'py> PySliceMethods<'py> for Bound<'py, PySlice>

§

fn indices(&self, length: isize) -> Result<PySliceIndices, PyErr>

Retrieves the start, stop, and step indices from the slice object, assuming a sequence of length length, and stores the length of the slice in its slicelength member.
§

impl<'py> PyStringMethods<'py> for Bound<'py, PyString>

§

fn to_str(&self) -> Result<&str, PyErr>

Gets the Python string as a Rust UTF-8 string slice. Read more
§

fn to_cow(&self) -> Result<Cow<'_, str>, PyErr>

Converts the PyString into a Rust string, avoiding copying when possible. Read more
§

fn to_string_lossy(&self) -> Cow<'_, str>

Converts the PyString into a Rust string. Read more
§

fn encode_utf8(&self) -> Result<Bound<'py, PyBytes>, PyErr>

Encodes this string as a Python bytes object, using UTF-8 encoding.
§

unsafe fn data(&self) -> Result<PyStringData<'_>, PyErr>

Obtains the raw data backing the Python string. Read more
§

impl PyTimeAccess for Bound<'_, PyDateTime>

§

fn get_hour(&self) -> u8

Returns the hour, as an int from 0 through 23. Read more
§

fn get_minute(&self) -> u8

Returns the minute, as an int from 0 through 59. Read more
§

fn get_second(&self) -> u8

Returns the second, as an int from 0 through 59. Read more
§

fn get_microsecond(&self) -> u32

Returns the microsecond, as an int from 0 through 999999. Read more
§

fn get_fold(&self) -> bool

Returns whether this date is the later of two moments with the same representation, during a repeated interval. Read more
§

impl PyTimeAccess for Bound<'_, PyTime>

§

fn get_hour(&self) -> u8

Returns the hour, as an int from 0 through 23. Read more
§

fn get_minute(&self) -> u8

Returns the minute, as an int from 0 through 59. Read more
§

fn get_second(&self) -> u8

Returns the second, as an int from 0 through 59. Read more
§

fn get_microsecond(&self) -> u32

Returns the microsecond, as an int from 0 through 999999. Read more
§

fn get_fold(&self) -> bool

Returns whether this date is the later of two moments with the same representation, during a repeated interval. Read more
§

impl<'py> PyTracebackMethods<'py> for Bound<'py, PyTraceback>

§

fn format(&self) -> Result<String, PyErr>

Formats the traceback as a string. Read more
§

impl<'py> PyTupleMethods<'py> for Bound<'py, PyTuple>

§

fn len(&self) -> usize

Gets the length of the tuple.
§

fn is_empty(&self) -> bool

Checks if the tuple is empty.
§

fn as_sequence(&self) -> &Bound<'py, PySequence>

Returns self cast as a PySequence.
§

fn into_sequence(self) -> Bound<'py, PySequence>

Returns self cast as a PySequence.
§

fn get_slice(&self, low: usize, high: usize) -> Bound<'py, PyTuple>

Takes the slice self[low:high] and returns it as a new tuple. Read more
§

fn get_item(&self, index: usize) -> Result<Bound<'py, PyAny>, PyErr>

Gets the tuple item at the specified index. Read more
§

fn get_borrowed_item<'a>( &'a self, index: usize, ) -> Result<Borrowed<'a, 'py, PyAny>, PyErr>

Like get_item, but returns a borrowed object, which is a slight performance optimization by avoiding a reference count change.
§

unsafe fn get_item_unchecked(&self, index: usize) -> Bound<'py, PyAny>

Gets the tuple item at the specified index. Undefined behavior on bad index. Use with caution. Read more
§

unsafe fn get_borrowed_item_unchecked<'a>( &'a self, index: usize, ) -> Borrowed<'a, 'py, PyAny>

Like get_item_unchecked, but returns a borrowed object, which is a slight performance optimization by avoiding a reference count change. Read more
§

fn as_slice(&self) -> &[Bound<'py, PyAny>]

Returns self as a slice of objects.
§

fn contains<V>(&self, value: V) -> Result<bool, PyErr>
where V: IntoPyObject<'py>,

Determines if self contains value. Read more
§

fn index<V>(&self, value: V) -> Result<usize, PyErr>
where V: IntoPyObject<'py>,

Returns the first index i for which self[i] == value. Read more
§

fn iter(&self) -> BoundTupleIterator<'py>

Returns an iterator over the tuple items.
§

fn iter_borrowed<'a>(&'a self) -> BorrowedTupleIterator<'a, 'py>

Like iter, but produces an iterator which returns borrowed objects, which is a slight performance optimization by avoiding a reference count change.
§

fn to_list(&self) -> Bound<'py, PyList>

Return a new list containing the contents of this tuple; equivalent to the Python expression list(tuple). Read more
§

impl<'py> PyTypeMethods<'py> for Bound<'py, PyType>

§

fn as_type_ptr(&self) -> *mut PyTypeObject

Retrieves the underlying FFI pointer associated with this Python object.

§

fn name(&self) -> Result<Bound<'py, PyString>, PyErr>

Gets the name of the PyType.

§

fn qualname(&self) -> Result<Bound<'py, PyString>, PyErr>

Gets the qualified name of the PyType.

§

fn module(&self) -> Result<Bound<'py, PyString>, PyErr>

Gets the name of the module defining the PyType.

§

fn fully_qualified_name(&self) -> Result<Bound<'py, PyString>, PyErr>

Gets the fully qualified name of the PyType.

§

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).

§

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.

§

fn mro(&self) -> Bound<'py, PyTuple>

Return the method resolution order for this type. Read more
§

fn bases(&self) -> Bound<'py, PyTuple>

Return Python bases Read more
§

impl<'py> PyTzInfoAccess<'py> for Bound<'py, PyDateTime>

§

fn get_tzinfo(&self) -> Option<Bound<'py, PyTzInfo>>

Returns the tzinfo (which may be None). Read more
§

fn get_tzinfo_bound(&self) -> Option<Bound<'py, PyTzInfo>>

👎Deprecated since 0.23.0: renamed to PyTzInfoAccess::get_tzinfo
Deprecated name for PyTzInfoAccess::get_tzinfo.
§

impl<'py> PyTzInfoAccess<'py> for Bound<'py, PyTime>

§

fn get_tzinfo(&self) -> Option<Bound<'py, PyTzInfo>>

Returns the tzinfo (which may be None). Read more
§

fn get_tzinfo_bound(&self) -> Option<Bound<'py, PyTzInfo>>

👎Deprecated since 0.23.0: renamed to PyTzInfoAccess::get_tzinfo
Deprecated name for PyTzInfoAccess::get_tzinfo.
§

impl<'py> PyWeakrefMethods<'py> for Bound<'py, PyWeakref>

§

fn upgrade(&self) -> Option<Bound<'py, PyAny>>

Upgrade the weakref to a Bound PyAny reference to the target object if possible. Read more
§

fn upgrade_as<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>
where T: PyTypeCheck,

Upgrade the weakref to a direct Bound object reference. Read more
§

unsafe fn upgrade_as_unchecked<T>(&self) -> Option<Bound<'py, T>>

Upgrade the weakref to a direct Bound object reference unchecked. The type of the recovered object is not checked before downcasting, this could lead to unexpected behavior. Use only when absolutely certain the type can be guaranteed. The weakref may still return None. Read more
§

fn upgrade_as_exact<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>
where T: PyTypeInfo,

Upgrade the weakref to a exact direct Bound object reference. Read more
§

fn get_object(&self) -> Bound<'py, PyAny>

👎Deprecated since 0.23.0: Use upgrade instead
Retrieve to a Bound object pointed to by the weakref. Read more
§

impl<'py> PyWeakrefMethods<'py> for Bound<'py, PyWeakrefProxy>

§

fn upgrade(&self) -> Option<Bound<'py, PyAny>>

Upgrade the weakref to a Bound PyAny reference to the target object if possible. Read more
§

fn upgrade_as<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>
where T: PyTypeCheck,

Upgrade the weakref to a direct Bound object reference. Read more
§

unsafe fn upgrade_as_unchecked<T>(&self) -> Option<Bound<'py, T>>

Upgrade the weakref to a direct Bound object reference unchecked. The type of the recovered object is not checked before downcasting, this could lead to unexpected behavior. Use only when absolutely certain the type can be guaranteed. The weakref may still return None. Read more
§

fn upgrade_as_exact<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>
where T: PyTypeInfo,

Upgrade the weakref to a exact direct Bound object reference. Read more
§

fn get_object(&self) -> Bound<'py, PyAny>

👎Deprecated since 0.23.0: Use upgrade instead
Retrieve to a Bound object pointed to by the weakref. Read more
§

impl<'py> PyWeakrefMethods<'py> for Bound<'py, PyWeakrefReference>

§

fn upgrade(&self) -> Option<Bound<'py, PyAny>>

Upgrade the weakref to a Bound PyAny reference to the target object if possible. Read more
§

fn upgrade_as<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>
where T: PyTypeCheck,

Upgrade the weakref to a direct Bound object reference. Read more
§

unsafe fn upgrade_as_unchecked<T>(&self) -> Option<Bound<'py, T>>

Upgrade the weakref to a direct Bound object reference unchecked. The type of the recovered object is not checked before downcasting, this could lead to unexpected behavior. Use only when absolutely certain the type can be guaranteed. The weakref may still return None. Read more
§

fn upgrade_as_exact<T>(&self) -> Result<Option<Bound<'py, T>>, PyErr>
where T: PyTypeInfo,

Upgrade the weakref to a exact direct Bound object reference. Read more
§

fn get_object(&self) -> Bound<'py, PyAny>

👎Deprecated since 0.23.0: Use upgrade instead
Retrieve to a Bound object pointed to by the weakref. Read more
§

impl<'py> Sub<&Bound<'py, PyComplex>> for Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the - operator.
§

fn sub(self, other: &Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the - operation. Read more
§

impl<'py> Sub<Bound<'py, PyComplex>> for &Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the - operator.
§

fn sub(self, other: Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the - operation. Read more
§

impl<'py> Sub for &Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the - operator.
§

fn sub(self, other: &Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the - operation. Read more
§

impl<'py> Sub for Bound<'py, PyComplex>

§

type Output = Bound<'py, PyComplex>

The resulting type after applying the - operator.
§

fn sub(self, other: Bound<'py, PyComplex>) -> Bound<'py, PyComplex>

Performs the - operation. Read more
§

impl<T> ToPyObject for Bound<'_, T>

§

fn to_object(&self, py: Python<'_>) -> Py<PyAny>

👎Deprecated since 0.23.0: ToPyObject is going to be replaced by IntoPyObject. See the migration guide (https://pyo3.rs/v0.23.0/migration) for more information.

Converts &Bound instance -> PyObject, increasing the reference count.

§

impl<'py> TryFrom<&Bound<'py, PyAny>> for Bound<'py, PyByteArray>

§

fn try_from( value: &Bound<'py, PyAny>, ) -> Result<Bound<'py, PyByteArray>, <Bound<'py, PyByteArray> as TryFrom<&Bound<'py, PyAny>>>::Error>

Creates a new Python bytearray object from another Python object that implements the buffer protocol.

§

type Error = PyErr

The type returned in the event of a conversion error.
§

impl<'py> TryFrom<&Bound<'py, PyAny>> for Bound<'py, PyMemoryView>

§

fn try_from( value: &Bound<'py, PyAny>, ) -> Result<Bound<'py, PyMemoryView>, <Bound<'py, PyMemoryView> as TryFrom<&Bound<'py, PyAny>>>::Error>

Creates a new Python memoryview object from another Python object that implements the buffer protocol.

§

type Error = PyErr

The type returned in the event of a conversion error.
§

impl TryFrom<Bound<'_, PyString>> for PyBackedStr

§

type Error = PyErr

The type returned in the event of a conversion error.
§

fn try_from( py_string: Bound<'_, PyString>, ) -> Result<PyBackedStr, <PyBackedStr as TryFrom<Bound<'_, PyString>>>::Error>

Performs the conversion.

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> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> ByteSized for T

Source§

const BYTE_ALIGN: usize = _

The alignment of this type in bytes.
Source§

const BYTE_SIZE: usize = _

The size of this type in bytes.
Source§

fn byte_align(&self) -> usize

Returns the alignment of this type in bytes.
Source§

fn byte_size(&self) -> usize

Returns the size of this type in bytes. Read more
Source§

fn ptr_size_ratio(&self) -> [usize; 2]

Returns the size ratio between Ptr::BYTES and BYTE_SIZE. Read more
Source§

impl<T, R> Chain<R> for T
where T: ?Sized,

Source§

fn chain<F>(self, f: F) -> R
where F: FnOnce(Self) -> R, Self: Sized,

Chain a function which takes the parameter by value.
Source§

fn chain_ref<F>(&self, f: F) -> R
where F: FnOnce(&Self) -> R,

Chain a function which takes the parameter by shared reference.
Source§

fn chain_mut<F>(&mut self, f: F) -> R
where F: FnOnce(&mut Self) -> R,

Chain a function which takes the parameter by exclusive reference.
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
§

impl<I> CollectIn for I
where I: Iterator,

§

fn collect_in<C>(self, alloc: <C as FromIteratorIn<Self::Item>>::Alloc) -> C
where C: FromIteratorIn<Self::Item>,

Collect all items from an iterator, into a collection parameterized by an allocator. Similar to Iterator::collect. Read more
Source§

impl<T> ExtAny for T
where T: Any + ?Sized,

Source§

fn type_id() -> TypeId

Returns the TypeId of Self. Read more
Source§

fn type_of(&self) -> TypeId

Returns the TypeId of self. Read more
Source§

fn type_name(&self) -> &'static str

Returns the type name of self. Read more
Source§

fn type_is<T: 'static>(&self) -> bool

Returns true if Self is of type T. Read more
Source§

fn as_any_ref(&self) -> &dyn Any
where Self: Sized,

Upcasts &self as &dyn Any. Read more
Source§

fn as_any_mut(&mut self) -> &mut dyn Any
where Self: Sized,

Upcasts &mut self as &mut dyn Any. Read more
Source§

fn as_any_box(self: Box<Self>) -> Box<dyn Any>
where Self: Sized,

Upcasts Box<self> as Box<dyn Any>. Read more
Source§

fn downcast_ref<T: 'static>(&self) -> Option<&T>

Available on crate feature unsafe_layout only.
Returns some shared reference to the inner value if it is of type T. Read more
Source§

fn downcast_mut<T: 'static>(&mut self) -> Option<&mut T>

Available on crate feature unsafe_layout only.
Returns some exclusive reference to the inner value if it is of type T. Read more
Source§

impl<T> ExtMem for T
where T: ?Sized,

Source§

const NEEDS_DROP: bool = _

Know whether dropping values of this type matters, in compile-time.
Source§

fn mem_align_of<T>() -> usize

Returns the minimum alignment of the type in bytes. Read more
Source§

fn mem_align_of_val(&self) -> usize

Returns the alignment of the pointed-to value in bytes. Read more
Source§

fn mem_size_of<T>() -> usize

Returns the size of a type in bytes. Read more
Source§

fn mem_size_of_val(&self) -> usize

Returns the size of the pointed-to value in bytes. Read more
Source§

fn mem_copy(&self) -> Self
where Self: Copy,

Bitwise-copies a value. Read more
Source§

fn mem_needs_drop(&self) -> bool

Returns true if dropping values of this type matters. Read more
Source§

fn mem_drop(self)
where Self: Sized,

Drops self by running its destructor. Read more
Source§

fn mem_forget(self)
where Self: Sized,

Forgets about self without running its destructor. Read more
Source§

fn mem_replace(&mut self, other: Self) -> Self
where Self: Sized,

Replaces self with other, returning the previous value of self. Read more
Source§

fn mem_take(&mut self) -> Self
where Self: Default,

Replaces self with its default value, returning the previous value of self. Read more
Source§

fn mem_swap(&mut self, other: &mut Self)
where Self: Sized,

Swaps the value of self and other without deinitializing either one. Read more
Source§

unsafe fn mem_zeroed<T>() -> T

Available on crate feature unsafe_layout only.
Returns the value of type T represented by the all-zero byte-pattern. Read more
Source§

unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst

Available on crate feature unsafe_layout only.
Returns the value of type T represented by the all-zero byte-pattern. Read more
Source§

fn mem_as_bytes(&self) -> &[u8]
where Self: Sync + Unpin,

Available on crate feature unsafe_slice only.
View a Sync + Unpin self as &[u8]. Read more
Source§

fn mem_as_bytes_mut(&mut self) -> &mut [u8]
where Self: Sync + Unpin,

Available on crate feature unsafe_slice only.
View a Sync + Unpin self as &mut [u8]. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<'py, T> FromPyObjectBound<'_, 'py> for T
where T: FromPyObject<'py>,

§

fn from_py_object_bound(ob: Borrowed<'_, 'py, PyAny>) -> Result<T, PyErr>

Extracts Self from the bound smart pointer obj. Read more
§

impl<S> FromSample<S> for S

§

fn from_sample_(s: S) -> S

Source§

impl<T> Hook for T

Source§

fn hook_ref<F>(self, f: F) -> Self
where F: FnOnce(&Self),

Applies a function which takes the parameter by shared reference, and then returns the (possibly) modified owned value. Read more
Source§

fn hook_mut<F>(self, f: F) -> Self
where F: FnOnce(&mut Self),

Applies a function which takes the parameter by exclusive reference, and then returns the (possibly) modified owned value. Read more
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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 more
Source§

impl<I> IntoIterator for I
where I: Iterator,

Source§

type Item = <I as Iterator>::Item

The type of the elements being iterated over.
Source§

type IntoIter = I

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> I

Creates an iterator from a value. Read more
§

impl<'py, T, I> IntoPyDict<'py> for I
where T: PyDictItem<'py>, I: IntoIterator<Item = T>,

§

fn into_py_dict(self, py: Python<'py>) -> Result<Bound<'py, PyDict>, PyErr>

Converts self into a PyDict object pointer. Whether pointer owned or borrowed depends on implementation.
§

fn into_py_dict_bound(self, py: Python<'py>) -> Bound<'py, PyDict>

👎Deprecated since 0.23.0: renamed to IntoPyDict::into_py_dict
Deprecated name for IntoPyDict::into_py_dict.
§

impl<'py, T> IntoPyObjectExt<'py> for T
where T: IntoPyObject<'py>,

§

fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>

Converts self into an owned Python object, dropping type information.
§

fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>

Converts self into an owned Python object, dropping type information and unbinding it from the 'py lifetime.
§

fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>

Converts self into a Python object. Read more
§

impl<F, T> IntoSample<T> for F
where T: FromSample<F>,

§

fn into_sample(self) -> T

§

impl<T> LayoutRaw for T

§

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>

Returns the layout of the type.
§

impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
where T: SharedNiching<N1, N2>, N1: Niching<T>, N2: Niching<T>,

§

unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool

Returns whether the given value has been niched. Read more
§

fn resolve_niched(out: Place<NichedOption<T, N1>>)

Writes data to out indicating that a T is niched.
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T> Pointee for T

§

type Metadata = ()

The metadata type for pointers and references to this type.
Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T, U> ToSample<U> for T
where U: FromSample<T>,

§

fn to_sample_(self) -> U

Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
§

impl<S, T> Duplex<S> for T
where T: FromSample<S> + ToSample<S>,