每天学一点Scala之 take、takeRight、takeWhile 与 filter
admin
2023-03-16 11:21:13
0

比较简单,直接上例子

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源码中,也有体现,如下:


每天学一点Scala之  take、takeRight、takeWhile 与 filter


总结:

    take(3)---> 表示,取出前3个元素

    takeRight(3)----> 表示,从后面/右边开始获取,取出3个元素

    takeWhile()---> 表示,从左边开始,将满足条件的元素取出来,直到遇到第一个不满足条件的元素

    filter --> 表示,取出所有满足条件的元素






相关内容

热门资讯

普京:收到泽连斯基希望会晤的口... 俄罗斯总统普京当地时间5月9日晚召开记者会,回答相关提问。普京表示,此次红场阅兵未展示军事装备,并不...
将论文“写”在秦岭云端 5月7日,团队成员正在进行激光光谱分光测试实验。 “我们在太白山主峰架起自主研制的激光雷达,可以实时...
成都人工智能产业实力领跑西部,... 近日,工业和信息化部发布2025年先进计算赋能新质生产力典型应用案例名单,成都3家人工智能领域企业 ...
铭凡发布「智能体NAS」:第三... 如果说过去几年,NAS市场的关键词还是“私有云”“家庭存储”和“影音库”,那么现在的情况已经悄然发生...
药王更替GIP靶点锋芒毕露 博... 来源:滚动播报 (来源:北京商报) 过去两年,减重药赛道极速完成了路径更迭。以礼来替尔泊肽为代表的G...
无凸轮十二轴弹簧机选型指南:东... 导语:在弹簧制造领域,无凸轮十二轴弹簧机凭借高精度、高效率、高灵活性的优势,成为新能源、航天航空、精...
AI 隐藏“思维链”,是怕被人... OpenAI 这些年最不缺的,就是被放大的人。 Sam Altman 当然不用说,几乎已经成了这家公...
美媒:以色列在伊拉克沙漠秘密建... 据《华尔街日报》5月9日报道,知情人士透露,以色列在伊拉克沙漠地带建立了一个秘密军事据点,以支持其针...
特朗普:预计“很快”收到伊朗对... △美国总统特朗(资料图)当地时间5月9日,央视记者获悉,美国总统特朗普表示,他预计“很快”会收到伊朗...
伊朗拟对霍尔木兹海峡的海底电缆... 据伊朗法尔斯通讯社5月9日报道,伊朗为途经霍尔木兹海峡、承担互联网通信业务的海底光缆,提出了一套管理...