如果我在Java中有List<List<String>>
数据,我可以通过代码获取第一个列表的长度:
int lengthData = data.get(0).size();
但是如何在不遍历列表列表的情况下获取结构中的列表数量?
也许我有点不清楚。我有结构:
List<List<String>> data
我明白了:
int i = data.size();
将等于1,因为它是根列表。所以我想知道的是有多少个子列表。遍历这样的结构:
for (List<String> l : data) {
total ++;
}
只给我一个我觉得奇怪的结果。
我有以下表格的数据:
List 1 ==> 1, 2, 3, 4
List 2 ==> 3, 8. 9, 1
等等这些是根列表的子列表。
答案 0 :(得分:63)
只需使用
int listCount = data.size();
它告诉你有多少列表(假设没有为空)。如果你想知道有多少 strings ,你需要迭代:
int total = 0;
for (List<String> sublist : data) {
// TODO: Null checking
total += sublist.size();
}
// total is now the total number of strings
答案 1 :(得分:1)
Java 8
import java.util.Arrays;
import java.util.List;
import java.util.ArrayList;
public class HelloWorld{
public static void main(String []args){
List<List<String>> stringListList = new ArrayList<>();
stringListList.add(Arrays.asList(new String[] {"(0,0)", "(0,1)"} ));
stringListList.add(Arrays.asList(new String[] {"(1,0)", "(1,1)", "(1,2)"} ));
stringListList.add(Arrays.asList(new String[] {"(2,0)", "(2,1)"} ));
int count=stringListList.stream().mapToInt(i -> i.size()).sum();
System.out.println("stringListList count: "+count);
}
}
答案 2 :(得分:0)
导入 java.util.ArrayList;
公共类测试类{
public static void main(String[] args) {
ArrayList<ArrayList<String>> listOLists = new ArrayList<ArrayList<String>>();
ArrayList<String> List_1 = new ArrayList<String>();
List_1.add("1");
List_1.add("2");
listOLists.add(List_1);
ArrayList<String> List_2 = new ArrayList<String>();
List_2.add("4");
List_2.add("5");
List_2.add("10");
List_2.add("11");
listOLists.add(List_2);
for (int i = 0; i < listOLists.size(); i++) {
System.out.print("list " + i + " :");
for (int j = 0; j < listOLists.get(i).size(); j++) {
System.out.print(listOLists.get(i).get(j) + " ;");
}
System.out.println();
}
}
}
答案 3 :(得分:0)
最外层列表中包含的列表数
int count = data.size();
lambda 获取包含的内部列表的数量
int count = data.stream().collect( summingInt(l -> l.size()) );