使用"或" Scala中使用Int的运算符

时间:2015-12-10 19:06:31

标签: scala

我需要将数据拆分成列。空白空间必须分布在最终列中。因此,如果我有四个元素和三列,则列将具有以下数量的元素:2,1和1。

我需要知道有多少列已满。答案是:

val full = data.length % NUMBER_OF_COLUMNS

问题在于项目数是列数的倍数,这会返回零,这不是我想要的。所以我可以做:

val full = if (data.length % NUMBER_OF_COLUMNS == 0) NUMBER_OF_COLUMNS else 
  data.length % NUMBER_OF_COLUMNS

这很有效,但感觉不太像Scala那样。"它绝对冗长而笨拙,其余操作需要存储或执行两次。 (在这里,我选择了后一种选择。)

有更好的方法吗?

在Python中,我所做的基本上是使用or运算符和Int,如下所示:

full = len(data) % NUMBER_OF_COLUMNS or NUMBER_OF_COLUMNS

完成。但我无法想到Scala中的类似内容。它不存在还是我根本没有看到它?

2 个答案:

答案 0 :(得分:5)

使用像这样的模式匹配

len % nCols match {
  case 0 => nCols
  case v => v
}

注意第二个模式匹配任何(非零)值并传递已经计算的mod值。

答案 1 :(得分:2)

Option(x).filter(_ != 0).getOrElse(numColumns)