Skip to main content

FromPyObject

Trait FromPyObject 

Source
pub trait FromPyObject<'a, 'py>: Sized {
    type Error: Into<PyErr>;

    // Required method
    fn extract(obj: Borrowed<'a, 'py, PyAny>) -> Result<Self, Self::Error>;
}
Expand description

Extract a type from a Python object.

Normal usage is through the extract methods on Bound, Borrowed and Py, which forward to this trait.

§Examples

use pyo3::prelude::*;
use pyo3::types::PyString;

Python::attach(|py| {
    // Calling `.extract()` on a `Bound` smart pointer
    let obj: Bound<'_, PyString> = PyString::new(py, "blah");
    let s: String = obj.extract()?;

    // Calling `.extract(py)` on a `Py` smart pointer
    let obj: Py<PyString> = obj.unbind();
    let s: String = obj.extract(py)?;
})

Note: Depending on the Python version and implementation, some FromPyObject implementations may produce a result that borrows into the Python type. This is described by the input lifetime 'a of obj.

Types that must not borrow from the input can use FromPyObjectOwned as a restriction. This is most often the case for collection types. See its documentation for more details.

§How to implement FromPyObject?

§#[derive(FromPyObject)]

The simplest way to implement FromPyObject for a custom type is to make use of our derive macro.

use pyo3::prelude::*;

#[derive(FromPyObject)]
struct MyObject {
    msg: String,
    list: Vec<u32>
}

By default this will try to extract each field from the Python object by attribute access, but this can be customized. For more information about the derive macro, its configuration as well as its working principle for other types, take a look at the guide.

In case the derive macro is not sufficient or can not be used for some other reason, FromPyObject can be implemented manually. In the following types without lifetime parameters are handled first, because they are a little bit simpler. Types with lifetime parameters are explained below.

§Manual implementation for types without lifetime

Types that do not contain lifetime parameters are unable to borrow from the Python object, so the lifetimes of FromPyObject can be elided:

use pyo3::prelude::*;

struct MyObject {
    msg: String,
    list: Vec<u32>
}

impl FromPyObject<'_, '_> for MyObject {
    type Error = PyErr;

    fn extract(obj: Borrowed<'_, '_, PyAny>) -> Result<Self, Self::Error> {
        Ok(MyObject {
            msg: obj.getattr("msg")?.extract()?,
            list: obj.getattr("list")?.extract()?,
        })
    }
}

This is basically what the derive macro above expands to.

§Manual implementation for types with lifetime paramaters

For types that contain lifetimes, these lifetimes need to be bound to the corresponding FromPyObject lifetime. This is roughly how the extraction of a typed Bound is implemented within PyO3.

use pyo3::prelude::*;
use pyo3::types::PyString;

struct MyObject<'py>(Bound<'py, PyString>);

impl<'py> FromPyObject<'_, 'py> for MyObject<'py> {
    type Error = PyErr;

    fn extract(obj: Borrowed<'_, 'py, PyAny>) -> Result<Self, Self::Error> {
        Ok(MyObject(obj.cast()?.to_owned()))
    }
}

§Details

Cow<'a, str> is an example of an output type that may or may not borrow from the input lifetime 'a. Which variant will be produced depends on the runtime type of the Python object. For a Python byte string, the existing string data can be borrowed for 'a into a Cow::Borrowed. For a Python Unicode string, the data may have to be reencoded to UTF-8, and copied into a Cow::Owned. It does not depend on the Python lifetime 'py.

The output type may also depend on the Python lifetime 'py. This allows the output type to keep interacting with the Python interpreter. See also Bound<'py, T>.

Required Associated Types§

Source

type Error: Into<PyErr>

The type returned in the event of a conversion error.

For most use cases defaulting to PyErr here is perfectly acceptable. Using a custom error type can be used to avoid having to create a Python exception object in the case where that exception never reaches Python. This may lead to slightly better performance under certain conditions.

§Note

Unfortunately Try and thus ? is based on From, not Into, so implementations may need to use .map_err(Into::into) sometimes to convert a generic Error into a PyErr.

Required Methods§

Source

fn extract(obj: Borrowed<'a, 'py, PyAny>) -> Result<Self, Self::Error>

Extracts Self from the bound smart pointer obj.

Users are advised against calling this method directly: instead, use this via Bound<'_, PyAny>::extract or Py::extract.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementations on Foreign Types§

Source§

impl FromPyObject<'_, '_> for IpAddr

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, '_, PyAny>, ) -> Result<IpAddr, <IpAddr as FromPyObject<'_, '_>>::Error>

Source§

impl FromPyObject<'_, '_> for bool

Converts a Python bool to a Rust bool.

Fails with TypeError if the input is not a Python bool.

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, '_, PyAny>, ) -> Result<bool, <bool as FromPyObject<'_, '_>>::Error>

Source§

impl FromPyObject<'_, '_> for char

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, '_, PyAny>, ) -> Result<char, <char as FromPyObject<'_, '_>>::Error>

Source§

impl FromPyObject<'_, '_> for i128

Source§

type Error = PyErr

Source§

fn extract( ob: Borrowed<'_, '_, PyAny>, ) -> Result<i128, <i128 as FromPyObject<'_, '_>>::Error>

Source§

impl FromPyObject<'_, '_> for u64

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, '_, PyAny>, ) -> Result<u64, <u64 as FromPyObject<'_, '_>>::Error>

Source§

impl FromPyObject<'_, '_> for u128

Source§

type Error = PyErr

Source§

fn extract( ob: Borrowed<'_, '_, PyAny>, ) -> Result<u128, <u128 as FromPyObject<'_, '_>>::Error>

Source§

impl FromPyObject<'_, '_> for usize

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, '_, PyAny>, ) -> Result<usize, <usize as FromPyObject<'_, '_>>::Error>

Source§

impl FromPyObject<'_, '_> for CString

Source§

impl FromPyObject<'_, '_> for String

Allows extracting strings from Python objects. Accepts Python str and unicode objects.

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, '_, PyAny>, ) -> Result<String, <String as FromPyObject<'_, '_>>::Error>

Source§

impl FromPyObject<'_, '_> for NonZero<i8>

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, '_, PyAny>, ) -> Result<NonZero<i8>, <NonZero<i8> as FromPyObject<'_, '_>>::Error>

Source§

impl FromPyObject<'_, '_> for NonZero<i16>

Source§

impl FromPyObject<'_, '_> for NonZero<i32>

Source§

impl FromPyObject<'_, '_> for NonZero<i64>

Source§

impl FromPyObject<'_, '_> for NonZero<i128>

Source§

impl FromPyObject<'_, '_> for NonZero<isize>

Source§

impl FromPyObject<'_, '_> for NonZero<u8>

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, '_, PyAny>, ) -> Result<NonZero<u8>, <NonZero<u8> as FromPyObject<'_, '_>>::Error>

Source§

impl FromPyObject<'_, '_> for NonZero<u16>

Source§

impl FromPyObject<'_, '_> for NonZero<u32>

Source§

impl FromPyObject<'_, '_> for NonZero<u64>

Source§

impl FromPyObject<'_, '_> for NonZero<u128>

Source§

impl FromPyObject<'_, '_> for NonZero<usize>

Source§

impl FromPyObject<'_, '_> for Duration

Source§

impl FromPyObject<'_, '_> for OsString

Source§

impl FromPyObject<'_, '_> for PathBuf

Source§

impl FromPyObject<'_, '_> for SystemTime

Source§

impl FromPyObject<'_, '_> for NaiveDate

Source§

impl FromPyObject<'_, '_> for NaiveDateTime

Source§

impl FromPyObject<'_, '_> for NaiveTime

Source§

impl FromPyObject<'_, '_> for FixedOffset

Source§

fn extract( ob: Borrowed<'_, '_, PyAny>, ) -> Result<FixedOffset, <FixedOffset as FromPyObject<'_, '_>>::Error>

Convert python tzinfo to rust FixedOffset.

Note that the conversion will result in precision lost in microseconds as chrono offset does not supports microseconds.

Source§

type Error = PyErr

Source§

impl FromPyObject<'_, '_> for Utc

Source§

type Error = PyErr

Source§

fn extract( ob: Borrowed<'_, '_, PyAny>, ) -> Result<Utc, <Utc as FromPyObject<'_, '_>>::Error>

Source§

impl FromPyObject<'_, '_> for TimeDelta

Source§

impl<'a> FromPyObject<'a, '_> for &'a str

Available on Py_3_10 or non-Py_LIMITED_API only.
Source§

type Error = PyErr

Source§

fn extract( ob: Borrowed<'a, '_, PyAny>, ) -> Result<&'a str, <&'a str as FromPyObject<'a, '_>>::Error>

Source§

impl<'a> FromPyObject<'a, '_> for &'a CStr

Available on Py_3_10 or non-Py_LIMITED_API only.
Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'a, '_, PyAny>, ) -> Result<&'a CStr, <&'a CStr as FromPyObject<'a, '_>>::Error>

Source§

impl<'a> FromPyObject<'a, '_> for Cow<'a, str>

Source§

type Error = PyErr

Source§

fn extract( ob: Borrowed<'a, '_, PyAny>, ) -> Result<Cow<'a, str>, <Cow<'a, str> as FromPyObject<'a, '_>>::Error>

Source§

impl<'a> FromPyObject<'a, '_> for Cow<'a, CStr>

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'a, '_, PyAny>, ) -> Result<Cow<'a, CStr>, <Cow<'a, CStr> as FromPyObject<'a, '_>>::Error>

Source§

impl<'a> FromPyObject<'a, '_> for Cow<'a, OsStr>

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'a, '_, PyAny>, ) -> Result<Cow<'a, OsStr>, <Cow<'a, OsStr> as FromPyObject<'a, '_>>::Error>

Source§

impl<'a> FromPyObject<'a, '_> for Cow<'a, Path>

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'a, '_, PyAny>, ) -> Result<Cow<'a, Path>, <Cow<'a, Path> as FromPyObject<'a, '_>>::Error>

Source§

impl<'a, 'py> FromPyObject<'a, 'py> for &'a [u8]

Source§

type Error = CastError<'a, 'py>

Source§

fn extract( obj: Borrowed<'a, 'py, PyAny>, ) -> Result<&'a [u8], <&'a [u8] as FromPyObject<'a, 'py>>::Error>

Source§

impl<'a, 'py> FromPyObject<'a, 'py> for Cow<'a, [u8]>

Special-purpose trait impl to efficiently handle both bytes and bytearray

If the source object is a bytes object, the Cow will be borrowed and pointing into the source object, and no copying or heap allocations will happen. If it is a bytearray, its contents will be copied to an owned Cow.

Source§

type Error = CastError<'a, 'py>

Source§

fn extract( ob: Borrowed<'a, 'py, PyAny>, ) -> Result<Cow<'a, [u8]>, <Cow<'a, [u8]> as FromPyObject<'a, 'py>>::Error>

Source§

impl<'a, 'py> FromPyObject<'a, 'py> for f32

Source§

type Error = <f64 as FromPyObject<'a, 'py>>::Error

Source§

fn extract( obj: Borrowed<'_, 'py, PyAny>, ) -> Result<f32, <f32 as FromPyObject<'a, 'py>>::Error>

Source§

impl<'a, 'py, T0> FromPyObject<'a, 'py> for (T0,)
where T0: FromPyObject<'a, 'py>,

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'a, 'py, PyAny>, ) -> Result<(T0,), <(T0,) as FromPyObject<'a, 'py>>::Error>

Source§

impl<'a, 'py, T0, T1> FromPyObject<'a, 'py> for (T0, T1)
where T0: FromPyObject<'a, 'py>, T1: FromPyObject<'a, 'py>,

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'a, 'py, PyAny>, ) -> Result<(T0, T1), <(T0, T1) as FromPyObject<'a, 'py>>::Error>

Source§

impl<'a, 'py, T0, T1, T2> FromPyObject<'a, 'py> for (T0, T1, T2)
where T0: FromPyObject<'a, 'py>, T1: FromPyObject<'a, 'py>, T2: FromPyObject<'a, 'py>,

Source§

impl<'a, 'py, T0, T1, T2, T3> FromPyObject<'a, 'py> for (T0, T1, T2, T3)
where T0: FromPyObject<'a, 'py>, T1: FromPyObject<'a, 'py>, T2: FromPyObject<'a, 'py>, T3: FromPyObject<'a, 'py>,

Source§

impl<'a, 'py, T0, T1, T2, T3, T4> FromPyObject<'a, 'py> for (T0, T1, T2, T3, T4)
where T0: FromPyObject<'a, 'py>, T1: FromPyObject<'a, 'py>, T2: FromPyObject<'a, 'py>, T3: FromPyObject<'a, 'py>, T4: FromPyObject<'a, 'py>,

Source§

impl<'a, 'py, T0, T1, T2, T3, T4, T5> FromPyObject<'a, 'py> for (T0, T1, T2, T3, T4, T5)
where T0: FromPyObject<'a, 'py>, T1: FromPyObject<'a, 'py>, T2: FromPyObject<'a, 'py>, T3: FromPyObject<'a, 'py>, T4: FromPyObject<'a, 'py>, T5: FromPyObject<'a, 'py>,

Source§

impl<'a, 'py, T0, T1, T2, T3, T4, T5, T6> FromPyObject<'a, 'py> for (T0, T1, T2, T3, T4, T5, T6)
where T0: FromPyObject<'a, 'py>, T1: FromPyObject<'a, 'py>, T2: FromPyObject<'a, 'py>, T3: FromPyObject<'a, 'py>, T4: FromPyObject<'a, 'py>, T5: FromPyObject<'a, 'py>, T6: FromPyObject<'a, 'py>,

Source§

impl<'a, 'py, T0, T1, T2, T3, T4, T5, T6, T7> FromPyObject<'a, 'py> for (T0, T1, T2, T3, T4, T5, T6, T7)
where T0: FromPyObject<'a, 'py>, T1: FromPyObject<'a, 'py>, T2: FromPyObject<'a, 'py>, T3: FromPyObject<'a, 'py>, T4: FromPyObject<'a, 'py>, T5: FromPyObject<'a, 'py>, T6: FromPyObject<'a, 'py>, T7: FromPyObject<'a, 'py>,

Source§

impl<'a, 'py, T0, T1, T2, T3, T4, T5, T6, T7, T8> FromPyObject<'a, 'py> for (T0, T1, T2, T3, T4, T5, T6, T7, T8)
where T0: FromPyObject<'a, 'py>, T1: FromPyObject<'a, 'py>, T2: FromPyObject<'a, 'py>, T3: FromPyObject<'a, 'py>, T4: FromPyObject<'a, 'py>, T5: FromPyObject<'a, 'py>, T6: FromPyObject<'a, 'py>, T7: FromPyObject<'a, 'py>, T8: FromPyObject<'a, 'py>,

Source§

impl<'a, 'py, T0, T1, T2, T3, T4, T5, T6, T7, T8, T9> FromPyObject<'a, 'py> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9)
where T0: FromPyObject<'a, 'py>, T1: FromPyObject<'a, 'py>, T2: FromPyObject<'a, 'py>, T3: FromPyObject<'a, 'py>, T4: FromPyObject<'a, 'py>, T5: FromPyObject<'a, 'py>, T6: FromPyObject<'a, 'py>, T7: FromPyObject<'a, 'py>, T8: FromPyObject<'a, 'py>, T9: FromPyObject<'a, 'py>,

Source§

impl<'a, 'py, T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> FromPyObject<'a, 'py> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10)
where T0: FromPyObject<'a, 'py>, T1: FromPyObject<'a, 'py>, T2: FromPyObject<'a, 'py>, T3: FromPyObject<'a, 'py>, T4: FromPyObject<'a, 'py>, T5: FromPyObject<'a, 'py>, T6: FromPyObject<'a, 'py>, T7: FromPyObject<'a, 'py>, T8: FromPyObject<'a, 'py>, T9: FromPyObject<'a, 'py>, T10: FromPyObject<'a, 'py>,

Source§

impl<'a, 'py, T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> FromPyObject<'a, 'py> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11)
where T0: FromPyObject<'a, 'py>, T1: FromPyObject<'a, 'py>, T2: FromPyObject<'a, 'py>, T3: FromPyObject<'a, 'py>, T4: FromPyObject<'a, 'py>, T5: FromPyObject<'a, 'py>, T6: FromPyObject<'a, 'py>, T7: FromPyObject<'a, 'py>, T8: FromPyObject<'a, 'py>, T9: FromPyObject<'a, 'py>, T10: FromPyObject<'a, 'py>, T11: FromPyObject<'a, 'py>,

Source§

impl<'a, 'py, T> FromPyObject<'a, 'py> for Option<T>
where T: FromPyObject<'a, 'py>,

Source§

type Error = <T as FromPyObject<'a, 'py>>::Error

Source§

fn extract( obj: Borrowed<'a, 'py, PyAny>, ) -> Result<Option<T>, <Option<T> as FromPyObject<'a, 'py>>::Error>

Source§

impl<'a, 'py, T> FromPyObject<'a, 'py> for Cell<T>
where T: FromPyObject<'a, 'py>,

Source§

type Error = <T as FromPyObject<'a, 'py>>::Error

Source§

fn extract( ob: Borrowed<'a, 'py, PyAny>, ) -> Result<Cell<T>, <Cell<T> as FromPyObject<'a, 'py>>::Error>

Source§

impl<'a, 'py, T, D> FromPyObject<'a, 'py> for PyReadonlyArray<'py, T, D>
where T: Element + 'a, D: Dimension + 'a,

Source§

type Error = CastError<'a, 'py>

Source§

fn extract( obj: Borrowed<'a, 'py, PyAny>, ) -> Result<PyReadonlyArray<'py, T, D>, <PyReadonlyArray<'py, T, D> as FromPyObject<'a, 'py>>::Error>

Source§

impl<'a, 'py, T, D> FromPyObject<'a, 'py> for PyReadwriteArray<'py, T, D>
where T: Element + 'a, D: Dimension + 'a,

Source§

type Error = CastError<'a, 'py>

Source§

fn extract( obj: Borrowed<'a, 'py, PyAny>, ) -> Result<PyReadwriteArray<'py, T, D>, <PyReadwriteArray<'py, T, D> as FromPyObject<'a, 'py>>::Error>

Source§

impl<'a, 'py, T, D, C> FromPyObject<'a, 'py> for PyArrayLike<'py, T, D, C>
where T: Element + 'py, D: Dimension + 'py, C: Coerce, Vec<T>: FromPyObject<'a, 'py>,

Source§

type Error = PyErr

Source§

fn extract( ob: Borrowed<'a, 'py, PyAny>, ) -> Result<PyArrayLike<'py, T, D, C>, PyErr>

Source§

impl<'py> FromPyObject<'_, 'py> for f64

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, 'py, PyAny>, ) -> Result<f64, <f64 as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py> FromPyObject<'_, 'py> for i8

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, 'py, PyAny>, ) -> Result<i8, <i8 as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py> FromPyObject<'_, 'py> for i16

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, 'py, PyAny>, ) -> Result<i16, <i16 as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py> FromPyObject<'_, 'py> for i32

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, 'py, PyAny>, ) -> Result<i32, <i32 as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py> FromPyObject<'_, 'py> for i64

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, 'py, PyAny>, ) -> Result<i64, <i64 as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py> FromPyObject<'_, 'py> for isize

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, 'py, PyAny>, ) -> Result<isize, <isize as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py> FromPyObject<'_, 'py> for u8

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, 'py, PyAny>, ) -> Result<u8, <u8 as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py> FromPyObject<'_, 'py> for u16

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, 'py, PyAny>, ) -> Result<u16, <u16 as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py> FromPyObject<'_, 'py> for u32

Source§

type Error = PyErr

Source§

fn extract( obj: Borrowed<'_, 'py, PyAny>, ) -> Result<u32, <u32 as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py, K> FromPyObject<'_, 'py> for BTreeSet<K>
where K: FromPyObjectOwned<'py> + Ord,

Source§

type Error = PyErr

Source§

fn extract( ob: Borrowed<'_, 'py, PyAny>, ) -> Result<BTreeSet<K>, <BTreeSet<K> as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py, K, S> FromPyObject<'_, 'py> for HashSet<K, S>
where K: FromPyObjectOwned<'py> + Eq + Hash, S: BuildHasher + Default,

Source§

type Error = PyErr

Source§

fn extract( ob: Borrowed<'_, 'py, PyAny>, ) -> Result<HashSet<K, S>, <HashSet<K, S> as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py, K, V> FromPyObject<'_, 'py> for BTreeMap<K, V>
where K: FromPyObjectOwned<'py> + Ord, V: FromPyObjectOwned<'py>,

Source§

impl<'py, K, V, S> FromPyObject<'_, 'py> for HashMap<K, V, S>
where K: FromPyObjectOwned<'py> + Eq + Hash, V: FromPyObjectOwned<'py>, S: BuildHasher + Default,

Source§

type Error = PyErr

Source§

fn extract( ob: Borrowed<'_, 'py, PyAny>, ) -> Result<HashMap<K, V, S>, <HashMap<K, V, S> as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py, K, V, S> FromPyObject<'_, 'py> for IndexMap<K, V, S>
where K: FromPyObjectOwned<'py> + Eq + Hash, V: FromPyObjectOwned<'py>, S: BuildHasher + Default,

Source§

type Error = PyErr

Source§

fn extract( ob: Borrowed<'_, 'py, PyAny>, ) -> Result<IndexMap<K, V, S>, <IndexMap<K, V, S> as FromPyObject<'_, 'py>>::Error>

Source§

impl<'py, T> FromPyObject<'_, 'py> for Vec<T>
where T: FromPyObjectOwned<'py>,

Source§

type Error = PyErr

Source§

fn extract(obj: Borrowed<'_, 'py, PyAny>) -> Result<Vec<T>, PyErr>

Source§

impl<'py, T, const N: usize> FromPyObject<'_, 'py> for [T; N]
where T: FromPyObjectOwned<'py>,

Source§

impl<'py, Tz> FromPyObject<'_, 'py> for DateTime<Tz>
where Tz: TimeZone + FromPyObjectOwned<'py>,

Source§

type Error = PyErr

Source§

fn extract( dt: Borrowed<'_, 'py, PyAny>, ) -> Result<DateTime<Tz>, <DateTime<Tz> as FromPyObject<'_, 'py>>::Error>

Implementors§

Source§

impl FromPyObject<'_, '_> for PyBackedStr

Source§

impl<'a, 'py> FromPyObject<'a, 'py> for PyBackedBytes

Source§

type Error = CastError<'a, 'py>

Source§

impl<'a, 'py, T> FromPyObject<'a, 'py> for PyClassGuard<'a, T>
where T: PyClass,

Source§

impl<'a, 'py, T> FromPyObject<'a, 'py> for PyClassGuardMut<'a, T>
where T: PyClass<Frozen = False>,

Source§

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

Source§

type Error = CastError<'a, 'py>

Source§

impl<'a, 'py, T> FromPyObject<'a, 'py> for Py<T>
where T: PyTypeCheck + 'a,

Source§

type Error = CastError<'a, 'py>

Source§

impl<'a, 'py, T> FromPyObject<'a, 'py> for PyRef<'py, T>
where T: PyClass,

Source§

impl<'a, 'py, T> FromPyObject<'a, 'py> for PyRefMut<'py, T>
where T: PyClass<Frozen = False>,

Source§

impl<'a, 'py, T> FromPyObject<'a, 'py> for T
where T: PyClass + Clone + ExtractPyClassWithClone,

Source§

impl<T> FromPyObject<'_, '_> for PyBuffer<T>
where T: Element,