Java利用TreeMap实现统计种类
生活随笔
收集整理的這篇文章主要介紹了
Java利用TreeMap实现统计种类
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
背景
有的時候需要統(tǒng)計一下表中某列各個種類的數(shù)量以及比例。例如:統(tǒng)計一個班,團員、黨員、群眾各有多少人。統(tǒng)計商品的種類,每個種類的商品有多少個。
本文提供了一種Java語言的解決方案。
代碼
import java.io.BufferedReader; import java.io.File; import java.io.FileReader; import java.io.IOException; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; import java.util.Map; import java.util.TreeMap;/*** @author yucheng*/ public class TypeStatics {public static void main(String[] args) {try {// 需要統(tǒng)計的列名String sortRow = "product_type";// csv文件的間隔符String regex = "\t";File tsv = new File("test.tsv");BufferedReader br = new BufferedReader(new FileReader(tsv));String[] headers = br.readLine().split(regex);Map<String, Integer> map = new TreeMap<>(Comparator.reverseOrder());String line;int count = 0;while ((line = br.readLine()) != null) {count++;String[] fields = line.split(regex);for (int i = 0; i < fields.length; i++) {if (sortRow.equals(headers[i])) {String key = fields[i];if (map.containsKey(key)) {int c = map.get(key) + 1;map.put(key, c);} else {map.put(key, 1);}}}}List<Map.Entry<String, Integer>> list = new ArrayList<>(map.entrySet());//然后通過比較器來實現(xiàn)排序,升序排序Collections.sort(list, (o1, o2) -> Integer.compare(o1.getValue() - o2.getValue(), 0));for (Map.Entry<String, Integer> mapping : list) {System.out.println(mapping.getKey() + ":" + mapping.getValue());}System.out.println(map.size());System.out.println(count);} catch (IOException e) {e.printStackTrace();}}}?
總結(jié)
以上是生活随笔為你收集整理的Java利用TreeMap实现统计种类的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: CRF++命名实体识别(NER)初步试探
- 下一篇: 华为云创建免费服务器的一次失败尝试