189 releases (105 stable)

new 1.0.106 Apr 3, 2020
1.0.105 Mar 18, 2020
1.0.104 Dec 16, 2019
1.0.103 Nov 25, 2019
0.0.0 Dec 5, 2014

#18 in Encoding

Download history 288399/week @ 2019-12-15 164481/week @ 2019-12-22 195558/week @ 2019-12-29 277322/week @ 2020-01-05 263704/week @ 2020-01-12 268067/week @ 2020-01-19 264655/week @ 2020-01-26 233476/week @ 2020-02-02 219387/week @ 2020-02-09 201525/week @ 2020-02-16 205938/week @ 2020-02-23 211511/week @ 2020-03-01 213593/week @ 2020-03-08 245924/week @ 2020-03-15 274764/week @ 2020-03-22 238878/week @ 2020-03-29

1,034,707 downloads per month
Used in 11,842 crates (7,277 directly)

MIT/Apache

475KB
10K 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 developers live in the #serde channel on irc.mozilla.org. The #rust channel is also a good resource with generally faster response time but less specific knowledge about Serde. If IRC is not your thing or you don't get a good response, we are happy to respond to GitHub issues as well.

Dependencies