2 stable releases

Uses old Rust 2015

1.0.119 Jan 19, 2021
1.0.104 Jan 8, 2020

#65 in #serde-derive

Download history 66/week @ 2024-03-11 72/week @ 2024-03-18 82/week @ 2024-03-25 97/week @ 2024-04-01 47/week @ 2024-04-08 108/week @ 2024-04-15 96/week @ 2024-04-22 71/week @ 2024-04-29 56/week @ 2024-05-06 62/week @ 2024-05-13 71/week @ 2024-05-20 52/week @ 2024-05-27 64/week @ 2024-06-03 44/week @ 2024-06-10 51/week @ 2024-06-17 63/week @ 2024-06-24

230 downloads per month
Used in 4 crates (3 directly)

MIT/Apache

280KB
6.5K SLoC

Serde is a framework for serializing and deserializing Rust data structures efficiently and generically.


You may be looking for:

Serde in action

use serde::{Serialize, Deserialize};

#[derive(Serialize, Deserialize, Debug)]
struct Point {
    x: i32,
    y: i32,
}

fn main() {
    let point = Point { x: 1, y: 2 };

    // Convert the Point to a JSON string.
    let serialized = serde_json::to_string(&point).unwrap();

    // Prints serialized = {"x":1,"y":2}
    println!("serialized = {}", serialized);

    // Convert the JSON string back to a Point.
    let deserialized: Point = serde_json::from_str(&serialized).unwrap();

    // Prints deserialized = Point { x: 1, y: 2 }
    println!("deserialized = {:?}", deserialized);
}

Getting help

Serde is one of the most widely used Rust libraries so any place that Rustaceans congregate will be able to help you out. For chat, consider trying the #general or #beginners channels of the unofficial community Discord, the #rust-usage channel of the official Rust Project Discord, or the #general stream in Zulip. For asynchronous, consider the [rust] tag on StackOverflow, the /r/rust subreddit which has a pinned weekly easy questions post, or the Rust Discourse forum. It's acceptable to file a support issue in this repo but they tend not to get as many eyes as any of the above and may get closed without a response after some time.

Dependencies

~1.5MB
~35K SLoC