每天學一點Scala之 take、takeRight、takeWhile 與 filter
阿新 • • 發佈:2017-09-08
filter takewhile scala
比較簡單,直接上例子
object takeWhileTest { def main(args: Array[String]): Unit = { val names = List("spark", "hadoop","kafka","hive", "mesos", "zero", "xyz","marathon") //需求:將names容器中,獲取/過濾出元素長度為4的元素, //takeWhile, 從第一個元素開始判斷,滿足條件,就留下,直到遇到第一個不滿足的條件的元素,就結束循環 //可見,takeWhile 有可能並不是對所有的元素進行操作的 names.takeWhile(_.length > 4 ).foreach{x => print(x + " ")} println("\n------------------") //從左邊開始獲取2個元素, names.take(2).foreach{x => print(x + " ")} println("\n------------------") //從右邊開始獲取4個元素, names.takeRight(4).foreach{x => print(x + " ")} println("\n------------------") //filter, 同樣,滿足條件,就留下。是對所有的元素,進行操作的 names.filter(_.length > 4).foreach{x => print(x + " ")}//將"xyz"元素,過濾掉了 } }
結果:
spark hadoop kafka ------------------ spark hadoop ------------------ mesos zero xyz marathon ------------------ spark hadoop kafka mesos marathon
同樣,marathon源碼中,也有體現,如下:
總結:
take(3)---> 表示,取出前3個元素
takeRight(3)----> 表示,從後面/右邊開始獲取,取出3個元素
takeWhile()---> 表示,從左邊開始,將滿足條件的元素取出來,直到遇到第一個不滿足條件的元素
filter --> 表示,取出所有滿足條件的元素
本文出自 “XEJ分布式工作室” 博客,請務必保留此出處http://xingej.blog.51cto.com/7912529/1963582
每天學一點Scala之 take、takeRight、takeWhile 與 filter