每天学一点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 --> 表示,取出所有满足条件的元素






相关内容

热门资讯

【第一财经】“乐乐上海麻将开挂... 【第一财经】“乐乐上海麻将开挂器?”(外卦神器下载)您好,乐乐上海麻将这个游戏其实有挂的,确实是有挂...
【今日要闻】“免安装麻将机辅助... 家人们!今天小编来为大家解答免安装麻将机辅助器透视挂怎么安装这个问题咨询软件客服徽9784099的挂...
玩家分享攻略“新毛豆牛牛是不是... 有 亲,根据资深记者爆料新毛豆牛牛是可以开挂的,确实有挂(咨询软件无需打...
终于明白“皮皮跑胡子是不是有挂... 家人们!今天小编来为大家解答皮皮跑胡子透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里买...
我来教教您“乐易四川麻将辅助器... 我来教教您“乐易四川麻将辅助器?”(透视曝光猫腻)您好,乐易四川麻将这个游戏其实有挂的,确实是有挂的...
今日重磅消息“掌酷天天开心到底... 今日重磅消息“掌酷天天开心到底是不是挂?”(必胜开挂神器)您好,掌酷天天开心这个游戏其实有挂的,确实...
日本一航空自卫队基地水体检出“... 近日,日本航空自卫队位于宫崎县的一处基地内部和周边多处水体检测出全氟和多氟烷基物质超标。最新公布的调...
最新引进“沈阳老友麻将辅助器?... 最新引进“沈阳老友麻将辅助器?”(必胜开挂神器)您好,沈阳老友麻将这个游戏其实有挂的,确实是有挂的,...
我来教教您“开心休闲可以开挂吗... 家人们!今天小编来为大家解答开心休闲透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买很...
苹果iPhone Fold外屏... 快科技12月24日消息,据报道,苹果首款折叠屏iPhone Fold外屏尺寸仅为5.3英寸,这比已经...