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

来源:互联网 发布:宝贝怎么优化标题 编辑:程序博客网 时间:2024/04/28 17:28

题目:
如在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;}@Overridepublic String toString() {    return "#" + name + "#" + score;}@Overridepublic int compareTo(Student o) {    if (score > o.getScore()) {        return -1;    } else if (score < o.getScore()) {        return 1;    } else {        return -name.compareTo(o.getName());    }}

}

阅读全文
0 0
原创粉丝点击