😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎😎 任务如下:
1计算每个同学的总分和平均分
2 统计每个科目的平均分
3 列出总分前3名和单科前3名,并保存结果到文件中
学生的成绩示例:
姓名,语文,数学,英语
张伟,87,92,88
李娜,90,85,95
王强,78,90,82
package score
/*
任务
* 1. 读入文件
* 2. 计算
* (1)每个同学的总分
* (2)每个学科的平均分
* (3)每个科目的最高分
* 3. 把结果写入到一个新文件中
*/
object score01 {
def main(args: Array[String]): Unit = {
// 1. 读入文件
val content = scala.io.Source.fromFile("score.txt").mkString
println(content)
}
}
(一)任务分析
分成三步来完成按行读入,并拆分。
(1)组装对象数组
(2)对对象数组做数据处理
(3)保存结果到文件
package score
object score02 {
def main(args: Array[String]): Unit = {
// println( "小英:100,80,90".split(":")(1) )
// 1. 读入文件 迭代器
val lines = scala.io.Source.fromFile("score.txt").getLines()
lines.next() // 读取第一个
while(lines.hasNext){
val line = lines.next()
// 字符串拆分
val li = line.split(":")
val name = li(0)
val yumen = li(1)
println(s"$name, $yumen")
}
}
}
(二)按行读取文本文件
由于一行表示一条数据,所以,我们可以一次读入一行。
(三)组装数据对象
思路:定义case class ,分别去new 对象,并赋值。
(四)分析数据
任务1:计算每个人的总分和平均分
代码如下
package score
object score03 {
case class Stu(name:String, yuwen:Double, shuxue:Double, yingyu:Double)
def main(args: Array[String]): Unit = {
// 0. 创建一个可变list
val stuList = scala.collection.mutable.ListBuffer[Stu]()
// 1. 读入文件 迭代器
val lines = scala.io.Source.fromFile("score.txt").getLines()
lines.next() // 跳过第一行
while(lines.hasNext){
val line = lines.next()
// 字符串拆分
val li = line.split(":")
val scores = li(1).split(",")
stuList += Stu(li(0), scores(0).toDouble, scores(1).toDouble, scores(2).toDouble)
}
// 读入数据结束
println("读入数据结束")
stuList.foreach(stu => {
val total = stu.yuwen + stu.yingyu + stu.shuxue
val avg = total / 3
println(s"${stu.name}, 总分: $total 平均分: $avg")
})
}
}
任务2:统计每个科目的平均分
package score
import java.io.FileWriter
object score03 {
case class Stu(name:String, yuwen:Double, shuxue:Double, yingyu:Double)
def main(args: Array[String]): Unit = {
// 0. 创建一个可变List
val stuList = scala.collection.mutable.ListBuffer[Stu]()
// 1. 读入文件 迭代器
val lines = scala.io.Source.fromFile("score.txt").getLines()
lines.next() // 跳过第一行
while(lines.hasNext){
val line = lines.next()
// 字符串拆分
val li = line.split(",")
stuList += Stu(li(0), li(1).toDouble, li(2).toDouble, li(3).toDouble)
}
// 读入数据结束
println("读入数据结束")
// 2. 计算
println("计算结束,开始写入")
// 3. 保存结果
val fileWriter = new FileWriter("score_result.txt")
fileWriter.write("高一19班成绩单 \n")
stuList.foreach(stu => {
val total = stu.yuwen + stu.yingyu + stu.shuxue
val avg = total / 3
fileWriter.write(s"${stu.name}, 总分: $total 平均分: $avg \n")
})
// 求单科最高分
fileWriter.write(s"语文最高分: ${stuList.map(_.yuwen).max} \n")
fileWriter.write(s"数学最高分: ${stuList.map(_.shuxue).max} \n")
fileWriter.write(s"英语最高分: ${stuList.map(_.yingyu).max} \n")
// println(stuList.map(_.yuwen).max)
fileWriter.close()
}
}