163 releases (78 stable)

1.0.77 Sep 7, 2018
1.0.75 Aug 25, 2018
1.0.70 Jul 7, 2018
1.0.36 Mar 27, 2018
0.0.0 Dec 5, 2014

#6 in Encoding

Download history 75174/week @ 2018-09-19 80292/week @ 2018-09-26 79923/week @ 2018-10-03 80073/week @ 2018-10-10 91544/week @ 2018-10-17 82469/week @ 2018-10-24 90192/week @ 2018-10-31 87591/week @ 2018-11-07 89759/week @ 2018-11-14 88178/week @ 2018-11-21 81085/week @ 2018-11-28 87883/week @ 2018-12-05 96377/week @ 2018-12-12

309,883 downloads per month
Used in 5,307 crates (3,304 directly)

MIT/Apache

465KB
10K SLoC

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


You may be looking for:

Serde in action

#[macro_use]
extern crate serde_derive;

extern crate serde;
extern crate serde_json;

#[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

  • build build.rs