首页 > 解决方案 > 如何通过匹配内部数组中的值来对数组列表中的数组进行分组?

问题描述

我有一个包含几个 String[] 的 ArrayList。我想遍历 ArrayList 并对包含匹配值的内部 String[] 进行分组。在这种情况下,我专门查看 String[] 中的第二个值(例如“CompanyA”)。

我很难理解什么是最好的逻辑模式以及如何实现它。任何帮助是极大的赞赏。

List<String[]> attArrayList = new ArrayList<String[]>();

String[] entry1 = { "EventOne", "CompanyA", "Matthew" };
String[] entry2= { "EventOne", "CompanyA", "Mary" };
String[] entry3 = { "EventOne", "CompanyB", "Bates" };
String[] entry4 = { "EventOne", "CompanyC", "Carson" };
attArrayList.add(entry1);
attArrayList.add(entry2);
attArrayList.add(entry3);
attArrayList.add(entry4);

for (int i = 0; i < attArrayList.size(); i++) {
  // ...
}

我想要的结果是这样的:

[[EventOne, CompanyA, Matthew], [EventOne, CompanyA, Mary]], [EventOne, CompanyB, Bates], [EventOne, CompanyC, Carson]

标签: javaarraysloopsfor-looparraylist

解决方案


Map<String, ArrayList<String[]>> map = new TreeMap<>();
    for (String[] strs : attArrayList) {
        if (!map.containsKey(strs[1])) {
            ArrayList<String[]> list = new ArrayList<>();
            list.add(strs);
            map.put(strs[1], list);
        } else {
            map.get(strs[1]).add(strs);
            map.put(strs[1], map.get(strs[1]));
        }
    }
    for (String[] strs : map.get("CompanyA")) {
        System.out.println(Arrays.toString(strs));
    }

你可以试试这个。我认为它比使用流更容易理解(虽然流的代码更少)。


推荐阅读