求单科最高分:
package score
import java.io.FileWriter
object score1 {
case class Stu(name:String, yuwen:Double, shuxue:Double, yingyu:Double)
def main(args: Array[String]): Unit = {
val stuList = scala.collection.mutable.ListBuffer[Stu]()
val lines = scala.io.Source.fromFile("score.txt").getLines()
lines.next()
while(lines.hasNext){
val line = lines.next()
val list = line.split(",")
stuList += Stu(list(0), list(1).toDouble,list(2).toDouble,list(3).toDouble)
}
val filewriter = new FileWriter("score_result.txt")
stuList.foreach(stu => {
val total = stu.yuwen + stu.shuxue + stu.yingyu
filewriter.write( s"${stu.name}, 总分:${total} 平均分:${total/3} \n")
println( s"${stu.name} 写入成功 ")
})
filewriter.write("最高分 \n")
filewriter.write(s"语文:${stuList.map(_.yuwen).max} \n")
filewriter.write(s"考了最高分的人是? \n")
filewriter.write(s"数学:${stuList.map(_.shuxue).max} \n")
filewriter.write(s"英语:${stuList.map(_.yingyu).max} \n")
filewriter.close()
}
}
得到 score_result.txt 文件:

求最高分的人
import java.io.FileWriter
object score1 {
case class Stu(name:String, yuwen:Double, shuxue:Double, yingyu:Double)
def main(args: Array[String]): Unit = {
val stuList = scala.collection.mutable.ListBuffer[Stu]()
val lines = scala.io.Source.fromFile("score.txt").getLines()
lines.next()
while(lines.hasNext){
val line = lines.next()
val list = line.split(",")
stuList += Stu(list(0), list(1).toDouble,list(2).toDouble,list(3).toDouble)
}
val filewriter = new FileWriter("score_result.txt")
stuList.foreach(stu => {
val total = stu.yuwen + stu.shuxue + stu.yingyu
filewriter.write( s"${stu.name}, 总分:${total} 平均分:${total/3} \n")
println( s"${stu.name} 写入成功 ")
})
filewriter.write("最高分 \n")
val yuwen_max = stuList.map(_.yuwen).max
filewriter.write(s"语文:${yuwen_max} \n")
filewriter.write(s" ${stuList.filter(_.yuwen == yuwen_max).map(_.name).mkString(",")}\n")
filewriter.write(s"数学:${stuList.map(_.shuxue).max} \n")
filewriter.write(s"英语:${stuList.map(_.yingyu).max} \n")
filewriter.close()
}
}
得到 score_result.txt 文件:
