bas*_*han 2 dictionary scala nested
我有一个具有以下结构的地图:
Map[String, Map[String, String]]
Run Code Online (Sandbox Code Playgroud)
是否有一种获得内部地图价值的优雅方式?
按照正常的方式做两次......
val m = Map("a" -> Map("b" -> "c"))
m("a")("b") // c
Run Code Online (Sandbox Code Playgroud)
第一个操作m("a")返回内部Map[String,String].第二个操作that("b")返回返回的Map内部的String.
它与以下相同:
val m = Map("a" -> Map("b" -> "c"))
val m2 = m("a") // Map(b -> c)
m2("b") // c
Run Code Online (Sandbox Code Playgroud)
另一方面,如果您认为他们的密钥可能不存在,那么请执行以下操作:
for {
x <- m.get("a") // x = Map(b -> c)
y <- x.get("b") // y = c
} yield y
// Some(c)
for {
x <- m.get("a") // x = Map(b -> c)
y <- x.get("d") // fails
} yield y
// None
for {
x <- m.get("c") // fails
y <- x.get("d") // doesn't run
} yield y
// None
Run Code Online (Sandbox Code Playgroud)
对于你的榜样,key2是一个Option,就是喜欢m.get(key1),所以你可以处理它以同样的方式:
val key1: String = "a"
val key2: Option[String] = Some("b")
for {
value1 <- m.get(key1)
k2 <- key2
value2 <- value1.get(k2)
} yield value2
// Some(c)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1806 次 |
| 最近记录: |