要求通过java读取文本并把文本中的每一行后面的三个成绩相加, 最后按从大到小的顺序输出到另一个文本文件中.

题目:
如在E盘下有一个Test.txt文本文件内容是

刘德华#89#77#60

张信哲#76#97#70

周杰伦#89#88#90

随便啦#87#70#80

要求通过java读取文本并把文本中的每一行后面的三个成绩相加,
最后按从大到小的顺序输出到另一个文本文件中.
输出后的文本文件内容应为:

周杰伦#267

张信哲#243

随便啦#237

刘德华#226

package 输入输出流;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.TreeSet;

public class Dq {
public static void main(String[] args) {
try {
System.out.println(“开始运行。。。”);
// 装学生的集合
TreeSet set = new TreeSet();
// 输入流
FileReader fr = new FileReader(new File(“e:\Test.txt”));
BufferedReader br = new BufferedReader(fr);
// 输出流
FileWriter fw = new FileWriter(new File(“e:\Test1.txt”));
BufferedWriter bw = new BufferedWriter(fw);
String line = null;
while ((line = br.readLine()) != null) {
// 注意,切割后,第一个位置是空格
String[] split = line.split(“#”);
int score = Integer.valueOf(split[2]) + Integer.valueOf(split[3]) + Integer.valueOf(split[4]);
Student stu = new Student(split[1], score);
set.add(stu);
}
// 输出到磁盘文件上
for (Student student : set) {
bw.write(student.toString());
bw.newLine();
}
// 关闭所有输入输出流
bw.close();
fw.close();
br.close();
fr.close();
System.out.println(“结束运行。。。”);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (NumberFormatException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}

class Student implements Comparable {
private String name;
private int score;

public Student(String name, int score) {
    super();
    this.name = name;
    this.score = score;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public int getScore() {
    return score;
}

public void setScore(int score) {
    this.score = score;
}

@Override
public String toString() {
    return "#" + name + "#" + score;
}

@Override
public int compareTo(Student o) {
    if (score > o.getScore()) {
        return -1;
    } else if (score < o.getScore()) {
        return 1;
    } else {
        return -name.compareTo(o.getName());
    }
}

}

  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值