java读取文件内容(正则表达式匹配)

已知文件score.txt内容如下: 语文85分,数学89分,英语75分,马列95分。 要求解析出其中的成绩数据,并计算总成绩

java 复制代码
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class ScoreCalculator {
    public static void main(String[] args) {
        String filename = "score.txt";
        String line;
        int totalScore = 0;
        
        // Regular expression to match scores
        Pattern pattern = Pattern.compile("(\\d+)分");
        
        try (BufferedReader br = new BufferedReader(new FileReader(filename))) {
            while ((line = br.readLine()) != null) {
                Matcher matcher = pattern.matcher(line);
                while (matcher.find()) {
                    // Extract the score and add it to the total score
                    totalScore += Integer.parseInt(matcher.group(1));
                }
            }
            System.out.println("总成绩: " + totalScore + "分");
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
  1. 导入必要的包:

    • java.io.BufferedReaderjava.io.FileReader 用于读取文件。
    • java.util.regex.Patternjava.util.regex.Matcher 用于匹配正则表达式。
  2. 定义主类和主方法:

    • public class ScoreCalculator 是主类。
    • public static void main(String[] args) 是主方法。
  3. 文件名和初始化总成绩:

    • String filename = "score.txt"; 定义文件名。
    • int totalScore = 0; 初始化总成绩为0。
  4. 正则表达式模式:

    • Pattern pattern = Pattern.compile("(\\d+)分"); 定义一个正则表达式模式,匹配以"分"结尾的数字。
  5. 读取文件并解析成绩:

    • 使用 BufferedReaderFileReader 读取文件内容。
    • while 循环逐行读取文件内容。
    • 在每行中使用 Matcher 查找匹配的成绩。
    • 将找到的成绩转换为整数并累加到 totalScore
  6. 输出总成绩:

    • System.out.println("总成绩: " + totalScore + "分"); 输出总成绩。
  7. 异常处理:

    • 使用 try-with-resources 语句来确保文件被正确关闭。
    • 捕获并打印可能的 IOException

运行结果

相关推荐
风象南1 天前
很多人说,AI 让技术平权了,小白也能乱杀老师傅 ?
人工智能·后端
雨中飘荡的记忆1 天前
ElasticJob分布式调度从入门到实战
java·后端
Se7en2581 天前
推理平台全景
后端
大漠_w3cpluscom1 天前
你学不会 CSS,不是笨,是方向错了
后端
cipher1 天前
ERC-4626 通胀攻击:DeFi 金库的"捐款陷阱"
前端·后端·安全
毅航1 天前
自然语言处理发展史:从规则、统计到深度学习
人工智能·后端
JxWang051 天前
Task04:字符串
后端
树獭叔叔1 天前
10-让模型更小更聪明,学而不忘:知识蒸馏与持续学习
后端·aigc·openai
JxWang051 天前
Task02:链表
后端