zoukankan      html  css  js  c++  java
  • 用JavaIO,正则表达式,HashMap统计一个文本单词数量

    import java.io.BufferedReader;
    import java.io.FileReader;
    import java.util.HashMap;
    
    
    
    public class WordCount {
        public static void main(String[] args) {
            HashMap<String, Integer>mp = new HashMap<>();
            mp.put("jack", 1);
            mp.put("Tom", 2);
            mp.put("rose", 3);
            mp.put("jack",4);
            
                
    //        System.out.println(mp);
    //        System.out.println(mp.size());
    //        System.out.println(mp.keySet());
    //        System.out.println(mp.values());
            
            try (BufferedReader in = new BufferedReader(new FileReader("filetest.txt"))
                ){
                String line;
                int c = 0;
                while(null != (line = in.readLine())) {
                    
                    String[] words = line.split("\W");//单词的边界                
                    for(String w : words) {
                        if(w.trim().length() == 0) continue;
    //                    if(w.trim().length() == 1) {
    //                        //长度为1
    //                        char cc = w.charAt(0);
    //                        if(!Character.isLetterOrDigit(c)) {
    //                            continue;
    //                        }
    //                    }
                        w = w.toLowerCase();//不分大小写的统计                    
                        if(!mp.containsKey(w)) {
                            mp.put(w, 1);
                        }else {
                            int n = mp.get(w);
                            mp.put(w, n+1);
                        }                    
                    }
                    
                }
                
                for(String key : mp.keySet()) {
                    int v = mp.get(key);
                    System.out.printf("%s	%d
    ",key,v);
                }
                
            } catch (Exception e) {
                // TODO: handle exception
            }
        }
    }

     输出:

    常见的正则表达式符号:

  • 相关阅读:
    [LeetCode] Letter Combinations of a Phone Number
    [LeetCode] Combinations
    [Algorithms] Longest Increasing Subsequence
    2.Orange安装
    1.Orange是什么鬼?
    5.motan之注解方式配置
    4.motan之集群调用
    3.motan之异步调用
    2、motan入门程序
    1、微博RPC框架Motan
  • 原文地址:https://www.cnblogs.com/zhangmingzhao/p/7011138.html
Copyright © 2011-2022 走看看