统计文件中姓名及出现次数的小例子

/**
 *
从类似如下的文本文件中读取出所有的姓名,并打印出重复的姓名和重复的次数,并按重复次数排序:
1,张三,28
2,李四,35
3,张三,28
4,王五,35
5,张三,28
6,李四,35
7,赵六,28
8,田七,35
 * @author 大蘑菇
 *
 */
public class CountName {
     /**
      * ①读取文件到字符串
      * ②按照换行分割成字符串数组
      * ③遍历字符串数组,取出姓名
      * ④将姓名和出现的次数存入map中;
      * ⑤利用 treeset整理结果;为此需要封装User,其中包含了name,以及count;需要在User 中实现comparable接口或者构造 treesetmap时传入comparator;
      *
      * @throws Exception
      */
     
     static class User /*implements Comparable<User>*/ {
          String name;
           int count ;
           public User(String name, int count) {
               super();
               this.name = name;
               this.count = count;
          }
           @Override
           public String toString() {
               return "User [name=" + name + ", count=" + count + "]" ;
          }
          
           /**
           * 方法一。使用comparable接口来进行排序;
           */
//        @Override
//        public int compareTo(User o) {
//            if(this.count>o.count)return -1;
//            if(this.count<o.count)return 1;
//            
//            return this.name.compareTo(o.name);
//            
//             return this.count>o.count?1:(this.count<o.count?-1:this.name.compareTo(o.name));
//            
//        }
          
     }
     
     public static void main(String[] args) throws Exception {
           //读取文件;
          File file= new File("d:\\test\\name.txt" );
          FileReader fr=new FileReader(file);
           int fileSize=(int) file.length();
           char[] buff=new char[fileSize];
          
           //用来存放名字和对应的次数;
          Map<String, Integer> map= new HashMap<String, Integer>();
          
           //安装次数由小到大排序后的结果;传入比较器,使用comparator来比较;这样元素再加入的时候就会调用比较方法,按照默认升序排列
          Set<User> sortedResult= new TreeSet<User>(new Comparator<User>() {

               @Override
               public int compare(User o1, User o2) {
//                 if(o1.count>o2.count)return -1;//默认是从小到大排列
//                 if(o1.count<o2.count)return 1;
//                 return o1.name.compareTo(o2.name);
                    //更简洁的写法
                    return o1.count >o2.count ? 1:(o1.count<o2.count ?-1:o1.name .compareTo(o2.name));
              }
          });
          
           int len=fr.read(buff);//得到读取的字符个数;
          String result= new String(buff,0,len);
          
          String[] strings = result.split( "\\s+");
           //将姓名提取出来;并将姓名和出现的次数放入到集合中;
           for (String string : strings) {
              string= new String(string.getBytes(),"utf-8" );//1,张三,28(解决乱码)
              System. out.println(string);
              
              String[] strings2 = string.split( ",");
              String name=strings2[1];
             //存入姓名以及对应的次数
              Integer count=map.get(name);
               if(count==null ){
                   map.put(name, 1);
              } else{
                   map.put(name, count+1);
              }
          }
           //遍历map,得到所有的entry集合,封装成user,加入到set集合中;
          Set<Map.Entry<String, Integer>> entrySet = map.entrySet();
          Iterator<Entry<String, Integer>> iterator = entrySet.iterator();
          
           while(iterator.hasNext()){
              Entry<String, Integer> entry = iterator.next();
               System. out.println(entry.getKey()+":" +entry.getValue()+"次");
              User user= new User(entry.getKey(), entry.getValue());
              sortedResult.add(user); //在加入数据时,自动安装 compareto定义的进行排序;
              
          }
           //遍历整理好的set,从小到大升序排列
          Iterator<User> it = sortedResult.iterator();
           while(it.hasNext()){
              User user=it.next();
              System. out.println(user);
          }
     }
     
     
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值