Is it possible to convert Option<Result<T, E>> to a Result<Option<T>, E> without using match?
问题 My first thought is to map the Option , but I can't use try! from inside of the closure. The match statement looks unnecessary, but I can't figure out how to simplify it. fn example<T, E>(val: Option<Result<T, E>>) -> Result<Option<T>, E> { Ok(match val { Some(v) => Some(v?), None => None }) } 回答1: You can use Option::map_or(): val.map_or(Ok(None), |v| v.map(Some)) 回答2: In Rust 1.33, transpose() is stable, so you can just call it: fn main() { let x: Result<Option<i32>, ()> = Ok(Some(5)); let