欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

spark2.1:rdd.combineByKeyWithClassTag的用法示例

发布时间:2024/4/14 编程问答 39 豆豆
生活随笔 收集整理的这篇文章主要介绍了 spark2.1:rdd.combineByKeyWithClassTag的用法示例 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

测试spark版本:

Spark context Web UI available at http://192.168.1.1:32735 Spark context available as 'sc' (master = local[*], app id = local-1380172893828). Spark session available as 'spark'. Welcome to____ __/ __/__ ___ _____/ /___\ \/ _ \/ _ `/ __/ '_//___/ .__/\_,_/_/ /_/\_\ version 2.1.0/_/Using Scala version 2.11.8 (Java HotSpot(TM) 64-Bit Server VM, Java 1.8.0_72) Type in expressions to have them evaluated. Type :help for more information.

备注:spark1.5中没有提供rdd.combineByKeyWithClassTag算子,但提供的有rdd.combineByKey算子(spark2.1中依然保留)。

使用示例:

scala> case class FModel(cgridid: Int, angle: Double, drsrp: Double, distance: Double) defined class FModelscala> val sample_rdd=sc.makeRDD(| Array(| (1,FModel(1,2.0,2.1,2.2)),| (1,FModel(2,2.2,2.11,23.2)),| (2,FModel(1,2.0,2.1,2.2)),| (1,FModel(3,2.0,42.1,22.2)),| (2,FModel(2,2.2,2.11,23.2)),| (3,FModel(3,2.0,42.1,22.2))| )| ) sample_rdd: org.apache.spark.rdd.RDD[(Int, FModel)] = ParallelCollectionRDD[0] at makeRDD at <console>:26scala> val combinByKeyRDD = sample_rdd.combineByKeyWithClassTag(| (x: FModel) => (List(x), 1),| (peo: (List[FModel], Int), x: FModel) => (x :: peo._1, peo._2 + 1),| (sex1: (List[FModel], Int), sex2: (List[FModel], Int)) => (sex1._1 ::: sex2._1, sex1._2 + sex2._2)) combinByKeyRDD: org.apache.spark.rdd.RDD[(Int, (List[FModel], Int))] = ShuffledRDD[1] at combineByKeyWithClassTag at <console>:28scala> combinByKeyRDD.foreach(println) [Stage 0:> (0 + 0) / 12](3,(List(FModel(3,2.0,42.1,22.2)),1)) (2,(List(FModel(1,2.0,2.1,2.2), FModel(2,2.2,2.11,23.2)),2)) (1,(List(FModel(1,2.0,2.1,2.2), FModel(2,2.2,2.11,23.2), FModel(3,2.0,42.1,22.2)),3))scala>

 

转载于:https://www.cnblogs.com/yy3b2007com/p/8506552.html

总结

以上是生活随笔为你收集整理的spark2.1:rdd.combineByKeyWithClassTag的用法示例的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。