Java HashMap ArrayList 操作
Java HashMap ArrayList manipulation
我真的被这个问题困住了。我已经有了这个代码和输出。
但我想要的是增强并使其更复杂。
这个逻辑可能吗?
String check = checkpoint1;
boolean passcheckpoint1= false;
int keyIndex = 0;
Map<String,ArrayList> hashMap = new HashMap();
List<String> keys = new ArrayList<String>();
ArrayList<String> nextValue = new ArrayList();
while(it.hasNext()){
line = it.nextLine();
if (line.contains(check)) {
passcheckpoint1 = true;
}
else if (passcheckpoint1) {
ArrayList<String> value = new ArrayList();
value.add(line);
hashMap.put(keys.get(keyIndex++), value);
}
else {
keys.add(line);
}
}
这是我的文本文件以前的数据。
1
2
3
4
checkpoint1
a
b
c
d
输出:
{1 = [a], 2=[b], 3=[c], 4=[d]}
现在这是我的文本文件的当前数据。
1
2
3
4
checkpoint1
a
b
c
d
checkpoint2
5
6
7
8
checkpoint3
e
f
g
h
预期输出:
{1 = [a], 2=[b], 3=[c], 4=[d] , 5=[e,f,g,h], 6=[e,f,g,h], 7=[e,f,g,h], 8=[e,f,g,h]}
我想做的是,把5,6,7,8和1,2,3,4一样放到hashmap的key中。但是现在它的价值都是一样的。我想将 e、f、g、h 放在一个数组列表中(nextValue - ArrayList)并将其放在 5,6,7,8
的值上
注:我没有测试。
Map<String, ArrayList<String>> hashMap = new HashMap();
int checkpoint = 0;
int i = 0;
List<String> keys1 = new ArrayList<String>();
List<String> keys2 = new ArrayList<String>();
List<String> keys3 = new ArrayList<String>();
while(it.hasNext()) {
line = it.nextLine();
if (line.contains('checkpoint1')) {
checkpoint = 1;
} else if (line.contains('checkpoint2')) {
checkpoint = 2;
} else if (line.contains('checkpoint3')) {
checkpoint = 3;
} else {
switch (checkpoint) {
case 0:
keys1.add(line);
break;
case 1:
List<String> values = new ArrayList<String>();
values.add(line);
hashMap.put(keys1.get(i++),values);
break;
case 2:
keys2.add(line);
break;
case 3:
keys3.add(line);
break;
}
}
}
for (String k: keys2){
hashMap.put(k,keys3);
}
我真的被这个问题困住了。我已经有了这个代码和输出。 但我想要的是增强并使其更复杂。 这个逻辑可能吗?
String check = checkpoint1;
boolean passcheckpoint1= false;
int keyIndex = 0;
Map<String,ArrayList> hashMap = new HashMap();
List<String> keys = new ArrayList<String>();
ArrayList<String> nextValue = new ArrayList();
while(it.hasNext()){
line = it.nextLine();
if (line.contains(check)) {
passcheckpoint1 = true;
}
else if (passcheckpoint1) {
ArrayList<String> value = new ArrayList();
value.add(line);
hashMap.put(keys.get(keyIndex++), value);
}
else {
keys.add(line);
}
}
这是我的文本文件以前的数据。
1
2
3
4
checkpoint1
a
b
c
d
输出:
{1 = [a], 2=[b], 3=[c], 4=[d]}
现在这是我的文本文件的当前数据。
1
2
3
4
checkpoint1
a
b
c
d
checkpoint2
5
6
7
8
checkpoint3
e
f
g
h
预期输出:
{1 = [a], 2=[b], 3=[c], 4=[d] , 5=[e,f,g,h], 6=[e,f,g,h], 7=[e,f,g,h], 8=[e,f,g,h]}
我想做的是,把5,6,7,8和1,2,3,4一样放到hashmap的key中。但是现在它的价值都是一样的。我想将 e、f、g、h 放在一个数组列表中(nextValue - ArrayList)并将其放在 5,6,7,8
的值上注:我没有测试。
Map<String, ArrayList<String>> hashMap = new HashMap();
int checkpoint = 0;
int i = 0;
List<String> keys1 = new ArrayList<String>();
List<String> keys2 = new ArrayList<String>();
List<String> keys3 = new ArrayList<String>();
while(it.hasNext()) {
line = it.nextLine();
if (line.contains('checkpoint1')) {
checkpoint = 1;
} else if (line.contains('checkpoint2')) {
checkpoint = 2;
} else if (line.contains('checkpoint3')) {
checkpoint = 3;
} else {
switch (checkpoint) {
case 0:
keys1.add(line);
break;
case 1:
List<String> values = new ArrayList<String>();
values.add(line);
hashMap.put(keys1.get(i++),values);
break;
case 2:
keys2.add(line);
break;
case 3:
keys3.add(line);
break;
}
}
}
for (String k: keys2){
hashMap.put(k,keys3);
}