take top takeOrdered 的基本使用方法

编程入门 行业动态 更新时间:2024-10-12 12:32:39

take top takeOrdered 的基本<a href=https://www.elefans.com/category/jswz/34/1769874.html style=使用方法"/>

take top takeOrdered 的基本使用方法

take
top
takeOrdered 的使用

        val spark = SparkSession.builder.master("local[*]").appName("TakeTakeOrderedTop").getOrCreate()val sc = spark.sparkContext// take, 不对数据进行排序,返回rdd 中从0到N 的下标表示的值val rdd1 = sc.parallelize(Seq(11, 2, 30, 4, 9, 100,8,90,99,8), 4)rdd1.take(90).foreach(println)println("----------------------------")// top 默认降序排序, 调用了takeOrder,// def top(num: Int)(implicit ord: Ordering[T]): Array[T] = withScope {// takeOrdered(num)(ord.reverse)//}val rdd2 = sc.makeRDD(Seq(11, 2, 30, 4, 9, -100,8,90,99,8), 8)rdd2.top(100).foreach(println)// 改变其默认排序方式implicit  val myOr = implicitly[Ordering[Int]].reverseprintln("-------------------------")rdd2.top(100).foreach(println)// 特殊数据类型需要指定排序方式, 特殊数据,每一列的数据格式需要是相同的val rdd3 = sc.parallelize(Array((1, 2, 3.0), (3, 2, 4.0), (1, 33, -5.0)))rdd3.top(100)(Ordering.by[(Int, Int, Double), Double](_._3).reverse).foreach(println)rdd3.top(100)(Ordering.by[(Int, Int, Double), Double](_._3)).foreach(println)// takeOrder, 普通数据类型会自动向上转型, 类似top, 默认是升序的val rdd4 = sc.makeRDD(List(1, -22, 33, 44.0, 5, 99.0, 0.99))rdd4.takeOrdered(9).foreach(println)

更多推荐

take top takeOrdered 的基本使用方法

本文发布于:2024-02-26 07:35:04,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1701756.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:使用方法   top   takeOrdered

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!