问题
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 y: Option<Result<i32, ()>> = Some(Ok(5));
assert_eq!(x, y.transpose());
}
来源:https://stackoverflow.com/questions/43166393/is-it-possible-to-convert-optionresultt-e-to-a-resultoptiont-e-without