List 如果使用scala键不存在,如何分离列表元素?
如果第二个元素不是“NA”,我想添加usedBytes。 我的预期输出是 usedSpace=所有列表元素的第一个值之和,其中第二个值不等于“NA” 自由空间=如果第二个值为“NA”,则列表中第一个值的总和 如何通过使用惯用的scala函数获得这些函数List 如果使用scala键不存在,如何分离列表元素?,list,scala,List,Scala,如果第二个元素不是“NA”,我想添加usedBytes。 我的预期输出是 usedSpace=所有列表元素的第一个值之和,其中第二个值不等于“NA” 自由空间=如果第二个值为“NA”,则列表中第一个值的总和 如何通过使用惯用的scala函数获得这些函数 List((1070071808,"NA",1077477376), (1070071808,aggr1,1077477376), (1070071808,aggr1,1077477376), (1070071808,aggr1,1077477
List((1070071808,"NA",1077477376), (1070071808,aggr1,1077477376),
(1070071808,aggr1,1077477376), (1070071808,aggr1,1077477376),
(1070071808,aggr1,1077477376), (1070071808,aggr1,1077477376),
(1070071808,aggr1,1077477376), (1070071808,aggr1,1077477376))
val list = List((1070071808, "NA", 1077477376), (1070071808, "aggr1", 1077477376),
(1070071808, "aggr1", 1077477376), (1070071808, "aggr1", 1077477376),
(1070071808, "aggr1", 1077477376), (1070071808, "aggr1", 1077477376),
(1070071808, "aggr1", 1077477376), (1070071808, "aggr1", 1077477376))
val (free, used) = list.partition(_._2 == "NA")
val freeSpace = free.foldLeft(0L)(_ + _._1) // uses Long to avoid overflow
val usedSpace = used.foldLeft(0L)(_ + _._1)