【Java基础】统计指定项目文件中字符出现的次数

需求分析

  •   统计当前项目下info2.txt文件中, 每个字符出现的个数
      文件内容如下:
      		welcome to itheima!!!
    	最终效果如下:
      		w(1) (2)!(3)t(2)e(3)c(1)a(1)o(2)l(1)m(2)h(1)i(2)
    

思路

  •  1.创建HashMap集合, 用于统计每个字符出现的次数
     2.创建输入流对象关联数据源
     3.读取到文件中的每一个字符
     4.判断字符是否是第一次出现
     	a)如果是的话, 键的位置存当前字符, 值的位置存1
     	b)如果不是第一次出现, 键的位置还是当前字符, 值的位置需要将原本记录的值取出, 然后+1存储
     5.创建字符串缓冲区(StringBuilder), 用于拼接结果
     6.将数据从集合中取出, 并拼接
     7.创建输出流对象
     8.调用write方法写出数据
     9.关闭流释放资源
    

代码

package com.itheima;

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map.Entry;

public class Test2 {
	public static void main(String[] args) throws IOException {
		//创建HashMap集合, 用于统计每个字符出现的次数
		HashMap<Character,Integer> hm = new HashMap();
		
		//创建输入流对象关联数据源
		FileInputStream fis = new FileInputStream("/Users/zhaozhuang/Downloads/develop/subject/day13-IO流/homework/day13作业答案/TestDay13/info2.txt");
		
		//读取到文件中的每一个字符
		int len;
		while((len = fis.read()) != -1) {
			char c = (char) len;
			//判断字符是否是第一次出现
			if(!hm.containsKey(c)) {
				//如果是的话, 键的位置存当前字符, 值的位置存1
				hm.put(c, 1);
			} else {
				//如果不是第一次出现, 键的位置还是当前字符, 值的位置需要将原本记录的值取出, 然后+1存储
				hm.put(c, hm.get(c) + 1);
			}
		}
		
		//创建字符串缓冲区(StringBuilder), 用于拼接结果
		StringBuilder sb = new StringBuilder();
		
		//将数据从集合中取出, 并拼接
		for(Entry<Character,Integer> en : hm.entrySet()) {
			sb.append(en.getKey()).append("(").append(en.getValue()).append(")");
		}
		
		//创建输出流对象
		FileOutputStream fos = new FileOutputStream("/Users/zhaozhuang/Downloads/develop/subject/day13-IO流/homework/day13作业答案/TestDay13/info2.txt");
		
		//调用write方法写出数据
		fos.write(sb.toString().getBytes());
		
		//释放资源
		fis.close();
		fos.close();
	}

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个Java程序,可以实现统计文本文件字符出现次数并按照出现次数排序的功能: ```java import java.io.*; import java.util.*; public class ChineseCharCount { public static void main(String[] args) { String filename = "test.txt"; // 待统计文件名 Map<Character, Integer> charMap = new HashMap<>(); // 用于存储字符出现次数的映射 try (BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(filename), "UTF-8"))) { String line; while ((line = reader.readLine()) != null) { for (int i = 0; i < line.length(); i++) { char c = line.charAt(i); if (isChineseChar(c)) { Integer count = charMap.get(c); if (count == null) { charMap.put(c, 1); } else { charMap.put(c, count + 1); } } } } } catch (IOException e) { e.printStackTrace(); } List<Map.Entry<Character, Integer>> charList = new ArrayList<>(charMap.entrySet()); // 将映射转换为列表 charList.sort((e1, e2) -> e2.getValue().compareTo(e1.getValue())); // 按照出现次数从大到小排序 for (Map.Entry<Character, Integer> entry : charList) { System.out.println(entry.getKey() + ": " + entry.getValue()); } } // 判断一个字符是否为字符 private static boolean isChineseChar(char c) { Character.UnicodeBlock ub = Character.UnicodeBlock.of(c); return ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A || ub == Character.UnicodeBlock.GENERAL_PUNCTUATION || ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION || ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS; } } ``` 程序首先读取指定的文本文件,逐行遍历文件每个字符,如果一个字符字符,则将其加入到一个映射,并记录其出现次数。最后,将映射转换为列表并按照出现次数从大到小排序,输出结果。 程序使用了`isChineseChar`方法来判断一个字符是否为字符,该方法判断的依据是该字符所属的`UnicodeBlock`是否为字符所使用的`UnicodeBlock`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值