2 stable releases

Uses old Rust 2015

1.0.119 Jan 19, 2021
1.0.104 Jan 8, 2020

#70 in #serde-derive

Download history 56/week @ 2024-07-19 62/week @ 2024-07-26 50/week @ 2024-08-02 68/week @ 2024-08-09 52/week @ 2024-08-16 33/week @ 2024-08-23 45/week @ 2024-08-30 48/week @ 2024-09-06 41/week @ 2024-09-13 61/week @ 2024-09-20 65/week @ 2024-09-27 19/week @ 2024-10-04 36/week @ 2024-10-11 41/week @ 2024-10-18 26/week @ 2024-10-25 40/week @ 2024-11-01

143 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
~37K SLoC