读取文件中出现次数最多的字符串

本文介绍了一个使用Java实现的文件读取程序,并展示了如何统计文件中每条记录出现的次数,找出出现频率最高的记录。通过示例代码,读者可以了解到如何使用BufferedReader逐行读取文件内容,以及如何利用LinkedHashMap进行数据统计。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package kryoDemo;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Map.Entry;

public class ReadFile {

	public static String readFile(File file) {
		StringBuilder sb = new StringBuilder();
		BufferedReader reader = null;
		try {
			reader = new BufferedReader(new FileReader(file));
			String tmpStr = null;
			// 一次读入一行,直到读入null为文件结束
			while ((tmpStr = reader.readLine()) != null) {
				sb.append(System.lineSeparator() + tmpStr);
			}
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			if (reader != null) {
				try {
					reader.close();
				} catch (IOException e) {
				}
			}
		}
		return sb.toString();
	}

	public static void main(String[] args) {
		File file = new File("E:/errlog.txt");
		if (!file.isFile() || !file.exists()) {
			throw new RuntimeException("not File Or file is not exist");
		}
		String str = readFile(file);
		String[] strArray = str.split(" |,");
		Map<String, Integer> m = new LinkedHashMap<String, Integer>(str.length());
		for (String detail : strArray) {
			m.put(detail, m.containsKey(detail) ? m.get(detail) + 1 : 1);
		}
		String maxStr = null;
		Integer maxNum = 0;
		for (Entry<String, Integer> entry : m.entrySet()) {
			if (entry.getValue() > maxNum) {
				maxNum = entry.getValue();
				maxStr = entry.getKey();
			}
		}
		System.out.println(maxStr);
	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值