使用java对文件中关键字进行统计,并作排序

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

package demo61;

import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.Map.Entry;
import java.util.TreeMap;

import org.apache.commons.io.FileUtils;
/**
 * 对字符串进行统计并作排序
 * @author mengfeiyang
 *
 */
public class KeywordCount {
	public static void main(String[] args) throws IOException {
		List ll = FileUtils.readLines(new File("test.txt"), "UTF-8");
		TreeMap treeMap = new TreeMap();
		for(String l : ll){
			String keyword = l.split(" ")[0];
			if(treeMap.containsKey(keyword)){
				int index = treeMap.get(keyword);
				index++;
				treeMap.put(keyword, index);
			}else{
				treeMap.put(keyword, 1);
			}
		}
		
		for(Entry  e : treeMap.entrySet()){
			System.out.println(e.getKey()+" --> "+e.getValue());
		}
		System.out.println("----排序后----");
		//--做排序
		List> sortMap = new ArrayList>(treeMap.entrySet());
		Collections.sort(sortMap, new Comparator>(){
			@Override
			public int compare(Entry o1,Entry o2) {
				//return o1.getValue() - o2.getValue(); //默认从小到大排序方式
				return -(o1.getValue() - o2.getValue()); //从大到小排序方式
			}
		});
		
		for (int i = 0; i < sortMap.size(); i++) {  
		    Entry ent=sortMap.get(i);  
		    System.out.println(ent.getKey()+" --> "+ent.getValue());  
		} 
	}
}
执行结果:
12345 --> 2
347834 --> 3
347835 --> 1
----排序后----
347834 --> 3
12345 --> 2
347835 --> 1
test.txt 中的内容:
12345 adfdf
347834 fkdfjkdjf
12345 adfdf
347834 adfdf2
347834 中文
347835 中文

 

转载于:https://my.oschina.net/u/2391658/blog/509575

你可能感兴趣的:(使用java对文件中关键字进行统计,并作排序)