12 breaking releases

0.23.0 Nov 22, 2024
0.21.1 Apr 2, 2024
0.20.0 Oct 15, 2023
0.19.0 Jun 11, 2023
0.12.0 Nov 22, 2020

#15 in FFI

Download history 18166/week @ 2024-08-17 20094/week @ 2024-08-24 17269/week @ 2024-08-31 23256/week @ 2024-09-07 15285/week @ 2024-09-14 20003/week @ 2024-09-21 19061/week @ 2024-09-28 21179/week @ 2024-10-05 20111/week @ 2024-10-12 19425/week @ 2024-10-19 21275/week @ 2024-10-26 23289/week @ 2024-11-02 23994/week @ 2024-11-09 21114/week @ 2024-11-16 20154/week @ 2024-11-23 21709/week @ 2024-11-30

91,721 downloads per month
Used in 28 crates (24 directly)

MIT license

61KB
1.5K SLoC

Pythonize

This is an experimental serializer for Rust's serde ecosystem, which can convert Rust objects to Python values and back.

At the moment the Python structures it produces should be very similar to those which are produced by serde_json; i.e. calling Python's json.loads() on a value encoded by serde_json should produce an identical structure to that which is produced directly by pythonize.

Usage

This crate converts Rust types which implement the Serde serialization traits into Python objects using the PyO3 library.

Pythonize has two main public APIs: pythonize and depythonize.

Examples

use serde::{Serialize, Deserialize};
use pyo3::prelude::*;
use pythonize::{depythonize, pythonize};

#[derive(Debug, Serialize, Deserialize, PartialEq)]
struct Sample {
    foo: String,
    bar: Option<usize>
}

let sample = Sample {
    foo: "Foo".to_string(),
    bar: None
};

Python::with_gil(|py| {
    // Rust -> Python
    let obj =  pythonize(py, &sample).unwrap();

    assert_eq!("{'foo': 'Foo', 'bar': None}", &format!("{}", obj.repr().unwrap()));

    // Python -> Rust
    let new_sample: Sample = depythonize(&obj).unwrap();

    assert_eq!(new_sample, sample);
})

Dependencies

~2.5MB
~55K SLoC