我在List [(Int,Double)]收集了一些财务数据,如下所示:
val snp = List((2001, -13.0), (2002, -23.4))
Run Code Online (Sandbox Code Playgroud)
有了这个,我写了一个公式,将列表,通过地图,转换成另一个列表(以证明投资等级人寿保险),其中低于0的损失转换为0,高于15的增益转换为15,如下所示:
case class EiulLimits(lower:Double, upper:Double)
def eiul(xs: Seq[(Int, Double)], limits:EiulLimits): Seq[(Int, Double)] = {
xs.map(item => (item._1,
if (item._2 < limits.lower) limits.lower
else if (item._2 > limits.upper) limits.upper
else item._2
}
Run Code Online (Sandbox Code Playgroud)
反正有没有在这里提取元组的值,所以我不必使用笨重的_1和_2表示法?
List((1,2),(3,4)).map { case (a,b) => ... }
Run Code Online (Sandbox Code Playgroud)
的case关键字调用模式匹配/不应用的逻辑.
注意之后使用花括号而不是parens map
并且代码的速度更慢但更短:
case class EiulLimits(lower: Double, upper: Double) {
def apply(x: Double) = List(x, lower, upper).sorted.apply(1)
}
def eiul(xs: Seq[(Int, Double)], limits: EiulLimits) = {
xs.map { case (a,b) => (a, limits(b)) }
}
Run Code Online (Sandbox Code Playgroud)
用法:
scala> eiul(List((1, 1.), (3, 3.), (4, 4.), (9, 9.)), EiulLimits(3., 7.))
res7: Seq[(Int, Double)] = List((1,3.0), (3,3.0), (4,4.0), (7,7.0), (9,7.0))
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1959 次 |
| 最近记录: |