Tom,DataBase,80

Tom,Algorithm,50

Tom,DataStructure,60

Jim,DataBase,90

Jim,Algorithm,60

Jim,DataStructure,80

.......

根据给定的数据在spark-shell中通过编程来计算以下内容

(1) 该系总共有多少学生;

  1. val lines = sc.textFile("file:///usr/local/spark/sparksqldata/Data01.txt")
  2. val par = lines.map(row=>row.split(",")(0))
  3. val distinct_par = par.distinct() //去重操作
  4. distinct_par.count //取得总数

  

答案为:265 人

(2) 该系共开设来多少门课程;

  1. val lines = sc.textFile("file:///usr/local/spark/sparksqldata/Data01.txt")
  2. val par = lines.map(row=>row.split(",")(1))//根据,切分的每行数据的第二列进行map
  3. val distinct_par = par.distinct()//去重
  4. distinct_par.count//取总数

  答案为 8 门

(3) Tom 同学的总成绩平均分是多少;

  1. val lines = sc.textFile("file:///usr/local/spark/sparksqldata/Data01.txt")
  2. val pare = lines.filter(row=>row.split(",")(0)=="Tom")
  3. pare.foreach(println)
  4. Tom,DataBase,26
  5. Tom,Algorithm,12
  6. Tom,OperatingSystem,16
  7. Tom,Python,40
  8. Tom,Software,60
  9. pare.map(row=>(row.split(",")(0),row.split(",")(2).toInt))
  10. .mapValues(x=>(x,1)).//mapValues是对值的操作,不操作key使数据变成(Tom,(26,1))
  11. reduceByKey((x,y) => (x._1+y._1,x._2 + y._2))//接着需要按key进行reduce,让key合并当将Tom进行reduce后 这里的(x,y) 表示的是(26,1)(12,1)
  12. .mapValues(x => (x._1 / x._2))//接着要对value进行操作,用mapValues()就行啦
  13. .collect()
  14. //res9: Array[(String, Int)] = Array((Tom,30))

  Tom 同学的平均分为 30 分

(4) 求每名同学的选修的课程门数;

  1. val lines = sc.textFile("file:///usr/local/spark/sparksqldata/Data01.txt")
  2. val pare = lines.map(row=>(row.split(",")(0),row.split(",")(1)))
  3. pare.mapValues(x => (x,1))//数据变为(Tom,(DataBase,1)),(Tom,(Algorithm,1)),(Tom,(OperatingSystem,1)),(Tom,(Python,1)),(Tom,(Software,1))
  1. .reduceByKey((x,y) => (" ",x._2 + y._2))//数据变为(Tom,( ,5))
  1. .mapValues(x =>x._2)//数据变为(Tom, 5)
  1. .foreach(println)
  1.  

  答案共 265 行

(5) 该系 DataBase 课程共有多少人选修

  1. val lines = sc.textFile("file:///usr/local/spark/sparksqldata/Data01.txt")
  2. val pare = lines.filter(row=>row.split(",")(1)=="DataBase")filter方法允许你提供一个判断条件(函数),来过滤集合元素
  3. pare.count
  4. res1: Long = 126

  答案为 126 人

(6) 各门课程的平均分是多少;

  1. val lines = sc.textFile("file:///usr/local/spark/sparksqldata/Data01.txt")
  2. val pare = lines.map(row=>(row.split(",")(1),row.split(",")(2).toInt))
  3. pare.mapValues(x=>(x,1)).reduceByKey((x,y) => (x._1+y._1,x._2 + y._2)).mapValues(x => (x._1 / x._2)).collect()
  4. res0: Array[(String, Int)] = Array((Python,57), (OperatingSystem,54), (CLanguage,50),
  5. (Software,50), (Algorithm,48), (DataStructure,47), (DataBase,50), (ComputerNetwork,51))

  答案为: (CLanguage,50) (Python,57) (Software,50) (OperatingSystem,54) (Algorithm,48) (DataStructure,47) (DataBase,50) (ComputerNetwork,51)

(7)使用累加器计算共有多少人选了 DataBase 这门课。

  1. val lines = sc.textFile("file:///usr/local/spark/sparksqldata/Data01.txt")
  2. val pare = lines.filter(row=>row.split(",")(1)=="DataBase").map(row=>(row.split(",")(1),1))
  3. val accum = sc.longAccumulator("My Accumulator")//累加器函数Accumulator
  4. pare.values.foreach(x => accum.add(x))
  5. accum.value
  6. res19: Long = 126

  答案:共有 126 人

2.编写独立应用程序实现数据去重

  1. 对于两个输入文件 A B,编写 Spark 独立应用程序,对两个文件进行合并,并剔除其
  2. 中重复的内容,得到一个新文件 C。下面是输入文件和输出文件的一个样例,供参考。
  3. 输入文件 A 的样例如下:
  4. 20170101 x
  5. 20170102 y
  6. 20170103 x
  7. 20170104 y
  8. 20170105 z
  9. 20170106 z
  10. 输入文件 B 的样例如下:
  11. 20170101 y
  12. 20170102 y
  13. 20170103 x
  14. 20170104 z
  15. 20170105 y
  16. 根据输入的文件 A B 合并得到的输出文件 C 的样例如下:
  17. 20170101 x
  18. 20170101 y
  19. 20170102 y
  20. 20170103 x
  21. 20170104 y
  22. 20170104 z
  23. 20170105 y
  24. 20170105 z
  25. 20170106 z

  eclipse代码

  1. package my.scala
  2. import org.apache.spark.{SparkConf, SparkContext}
  3. object case2 {
  4. def main(args: Array[String]): Unit = {
  5. val conf = new SparkConf().setMaster("local").setAppName("reduce")
  6. val sc = new SparkContext(conf)
  7. sc.setLogLevel("ERROR")
  8. //获取数据
  9. val two = sc.textFile("hdfs://192.168.85.128:9000/quchong")
  10. two.filter(_.trim().length>0) //需要有空格。
  11. .map(line=>(line.trim,""))//全部值当key,(key value,"")
  12. .groupByKey()//groupByKey,过滤重复的key value ,发送到总机器上汇总
  13. .sortByKey() //按key value的自然顺序排序
  14. .keys.collect().foreach(println) //所有的keys变成数组再输出
  15. //第二种有风险
  16. two.filter(_.trim().length>0)
  17. .map(line=>(line.trim,"1"))
  18. .distinct()
  19. .reduceByKey(_+_)
  20. .sortByKey()
  21. .foreach(println)
  22.  
  23. //reduceByKey,在本机suffle后,再发送一个总map,发送到一个总机器上汇总,(汇总要压力小)
  24. //groupByKey,发送本机所有的map,在一个机器上汇总(汇总压力大)
  25. //如果数据在不同的机器上,则会出现先重复数据,distinct,reduceBykey,只是在本机上去重,谨慎一点的话,在reduceByKey后面需要加多一个distinct
  26.  
  27. }
  28. }

  

  1. 3.编写独立应用程序实现求平均值问题
  2. 每个输入文件表示班级学生某个学科的成绩,每行内容由两个字段组成,第一个是学生
  3. 名字,第二个是学生的成绩;编写 Spark 独立应用程序求出所有学生的平均成绩,并输出到
  4. 一个新文件中。下面是输入文件和输出文件的一个样例,供参考。
  5. Algorithm 成绩:
  6. 小明 92
  7. 小红 87
  8. 小新 82
  9. 小丽 90
  10. Database 成绩:
  11. 小明 95
  12. 小红 81
  13. 小新 89
  14. 小丽 85
  15. Python 成绩:
  16. 小明 82
  17. 小红 83
  18. 小新 94
  19. 小丽 91
  20. 平均成绩如下:
  21. (小红,83.67)
  22. (小新,88.33)
  23. (小明,89.67)
  24. (小丽,88.67)

  

  1. package my.scala
  2. import org.apache.spark.{SparkConf, SparkContext}
  3. object pingjunzhi {
  4. def main(args: Array[String]): Unit = {
  5. val conf = new SparkConf().setMaster("local").setAppName("reduce")
  6. val sc = new SparkContext(conf)
  7. sc.setLogLevel("ERROR")
  8.  
  9. val fourth = sc.textFile("hdfs://192.168.85.128:9000/pingjunzhi")
  10.  
  11. val res = fourth.filter(_.trim().length>0).map(line=>(line.split("\t")(0).trim(),line.split("\t")(1).trim().toInt)).groupByKey().map(x => {
  12. var num = 0.0
  13. var sum = 0
  14. for(i <- x._2){
  15. sum = sum + i
  16. num = num +1
  17. }
  18. val avg = sum/num
  19. val format = f"$avg%1.2f".toDouble
  20. (x._1,format)
  21. }).collect.foreach(x => println(x._1+"\t"+x._2))
  22. }
  23. }

  

spark-shell的Scala的一些方法详解的更多相关文章

  1. (转)shell中test命令方法详解

    test命令用法.功能:检查文件和比较值 shell中test命令方法详解 原文:https://www.cnblogs.com/guanyf/p/7553940.html 1)判断表达式 if te ...

  2. telnet 命令使用方法详解,telnet命令怎么用

    telnet 命令使用方法详解,telnet命令怎么用? 文章类型:电脑教程 原创:天诺时空   什么是Telnet? 对于Telnet的认识,不同的人持有不同的观点,可以把Telnet当成一种通信协 ...

  3. [转帖]Vim编辑器使用方法详解

    Vim编辑器使用方法详解 程序员小新人学习 2018-12-16 12:26:23 转载于https://www.cnblogs.com/libaoliang/articles/6961676.htm ...

  4. 【Python】Linux crontab定时任务配置方法(详解)

    CRONTAB概念/介绍 crontab命令用于设置周期性被执行的指令.该命令从标准输入设备读取指令,并将其存放于“crontab”文件中,以供之后读取和执行. cron 系统调度进程. 可以使用它在 ...

  5. Linux中让alias设置永久生效的方法详解

    Linux中让alias设置永久生效的方法详解 一.问题描述 1.有很多时候我们想要将很多操作作为一个步骤,那么在不作为系统的服务的情况下,别名是我们最好的选择,但是发现别名只能在一次会话中生效,重启 ...

  6. Python学习之旅—生成器对象的send方法详解

    前言 在上一篇博客中,笔者带大家一起探讨了生成器与迭代器的本质原理和使用,本次博客将重点聚焦于生成器对象的send方法. 一.send方法详解  我们知道生成器对象本质上是一个迭代器.但是它比迭代器对 ...

  7. session的使用方法详解

    session的使用方法详解 Session是什么呢?简单来说就是服务器给客户端的一个编号.当一台WWW服务器运行时,可能有若干个用户浏览正在运正在这台服务器上的网站.当每个用户首次与这台WWW服务器 ...

  8. Kooboo CMS - Html.FrontHtml[Helper.cs] 各个方法详解

    下面罗列了方法详解,每一个方法一篇文章. Kooboo CMS - @Html.FrontHtml().HtmlTitle() 详解 Kooboo CMS - Html.FrontHtml.Posit ...

  9. HTTP请求方法详解

    HTTP请求方法详解 请求方法:指定了客户端想对指定的资源/服务器作何种操作 下面我们介绍HTTP/1.1中可用的请求方法: [GET:获取资源]     GET方法用来请求已被URI识别的资源.指定 ...

随机推荐

  1. ssl证书专题(3):创建CA和申请证书

    请看:  https://www.cnblogs.com/mingzhang/p/8949541.html

  2. TopCoder SRM704 Div1 800 构造

    原文链接https://www.cnblogs.com/zhouzhendong/p/SRM704-800.html 题解 考虑构造一个 $n = 20$ 的图. 先把所有 $i$ 都连向 $i-1$ ...

  3. hdu5705

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5705 题目: Problem Description Given a time HH:MM:SS an ...

  4. nginx 配置laravel框架域名配置

    server { listen 80; server_name admin.meiquick.local.com; #charset koi8-r; # access_log /var/log/ngi ...

  5. ListView 上拉加载更多

    ListView 上拉加载更多 首先来个效果图 界面布局 <?xml version="1.0" encoding="utf-8"?> <Re ...

  6. 2017-10-22—光电二极管

    光通信基本每天都会接触光电二极管,光模块说简单点就是电光转换和光电转换. 光传输模块在整体产品架构上则包括光学次模块(Optical Subassembly;OSA)及电子次模块(Electrical ...

  7. jquery for循环判断是否重复

    //使用for循环 判断是否有重名 var len=$("li").length;//获取页面中所有li的数量 for(var i=0; i<len; i++){ oldna ...

  8. 排序算法的复习和总结[PHP实现]

    对于PHP中对数组的元素进行排序,这个是很经常用到的,之前的项目中也有,而且对于几种排序我们都是用的是asort  arsort 等PHP原生函数,没有自己去实现,所以就对一下的几个函数进行总结,这个 ...

  9. Web项目中手机注册短信验证码实现的全流程及代码

    最近在做只能净化器的后台用户管理系统,需要使用手机号进行注册,找了许久才大致了解了手机验证码实现流程,今天在此和大家分享一下. 我们使用的是榛子云短信平台, 官网地址:http://smsow.zhe ...

  10. 泡泡一分钟:Cooperative Object Transportation by Multiple Ground and Aerial Vehicles: Modeling and Planning

    张宁 Cooperative Object Transportation by Multiple Ground and Aerial Vehicles: Modeling and Planning 多 ...