Scala关于成绩的常规操作

复制代码
score.txt中的数据:

姓名,语文,数学,英语

张伟,87,92,88

李娜,90,85,95

王强,78,90,82

赵敏,92,88,91

孙涛,85,82,89

周梅,88,87,93

吴刚,80,85,86

郑洁,91,89,94

陈晨,83,84,88

林峰,86,91,87

复制代码
Scala 复制代码
import scala.collection.mutable.ListBuffer
import scala.io.Source
//1.迭代器,跳过第一个元素
//2.把字符串转成数字
//3.如何判断一个正整数是否可以被3整除? (1+2+3) % 3 == 0

case class Student(name:String,yuwen:Int,shuxue:Int,yingyu:Int,total:Int,avg:Int)
//成绩分析
object Test {
  def main(args: Array[String]): Unit = {
    //0.定义一个空列表
    val list = ListBuffer[Student]()
    //1.读入成绩,按行读取,跳过第一个元素
    val it = Source.fromFile("score.txt").getLines().drop(1)
    var shuxuezongfen = 0
    while (it.hasNext) {
      val content = it.next()
      //使用中文的逗号去拆分字符串
      var arr = content.split(",")
      val name = arr(0)
      val yuwen = arr(1).toInt
      val shuxue = arr(2).toInt
      val yingyu = arr(3).toInt
      val total = yuwen + shuxue + yingyu
      val avg = total / 3

      shuxuezongfen += shuxue
      //创建一个对象
      list += Student(name, yuwen, shuxue, yingyu, total, avg)
    }
    //数学平均分
    println("数学平均分",shuxuezongfen / list.length)
    //根据总分进行排序
    val orderList = list.sortWith((a,b)=>a.total>b.total).slice(0,3)
    //打印结果
    orderList.foreach(s=>println(s"姓名:${s.name},总分:${s.total}"))

    //根据数学成绩进行排序
    list.sortWith((a,b)=>a.shuxue>b.shuxue)
    .foreach(s=> println(s"姓名:${s.name},数学:${s.shuxue},总分:${s.total}"))
  }
}
相关推荐
Java水解21 小时前
Scala深入面向对象:类、对象与伴生关系
后端·scala
哈哈很哈哈5 天前
Spark 核心 RDD详解
大数据·分布式·spark·scala
DTS小夏5 天前
Linux 系统 + IDEA+Scala 插件:新手进阶开发指南
linux·scala·intellij-idea
渣渣盟6 天前
Spark核心:单跳转换率计算全解析
大数据·spark·scala·apache
闯闯桑8 天前
Spark 中spark.implicits._ 中的 toDF和DataFrame 类本身的 toDF 方法
大数据·ajax·spark·scala
MOMO陌染10 天前
IDEA环境搭建与输出
scala
闯闯桑12 天前
toDF(columns: _*) 语法
开发语言·前端·spark·scala·apache
q5673152313 天前
无需Python:Shell脚本如何成为你的自动化爬虫引擎?
开发语言·爬虫·python·自动化·scala
渣渣盟15 天前
Spark自定义累加器实现高效WordCount
大数据·spark·scala
IvanCodes16 天前
一、Scala 基础语法、变量与数据类型
大数据·开发语言·scala