我需要将数据拆分成列.空白空间必须分布在最终列中.因此,如果我有四个元素和三列,则列将具有以下数量的元素: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中,我所做的基本上是使用带有Int的or运算符,如下所示:
full = len(data) % NUMBER_OF_COLUMNS or NUMBER_OF_COLUMNS
完成.但我不能想到Scala中有类似的东西.它不存在还是我根本没有看到它?
解决方法
像这样使用模式匹配
len % nCols match { case 0 => nCols case v => v }
请注意,第二个模式匹配任何(非零)值并提供已计算的mod值.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。