HashMapのArrayListがあります。その中でHashMapを検索したいのですが、これを実現する方法が見つかりません。どうすればいいのか教えてください。ありがとう。
質問する
13964 次
6 に答える
7
私が理解した方法であなたの質問に答えてください!
for (HashMap<String, String> hashMap : yourArrayList)
{
// For each hashmap, iterate over it
for (Map.Entry<String, String> entry : hashMap.entrySet())
{
// Do something with your entrySet, for example get the key.
String sListName = entry.getKey();
}
}
ハッシュマップは他のタイプを使用する可能性があります。これは文字列を使用します。
于 2012-07-10T20:20:41.220 に答える
4
これが役立つかどうかを確認します。
@Test
public void searchMap() {
List<Map<String, String>> listOfMaps = new ArrayList<Map<String,String>>();
Map<String, String> map1 = new HashMap<String, String>();
map1.put("key1", "value1");
Map<String, String> map2 = new HashMap<String, String>();
map1.put("key2", "value2");
Map<String, String> map3 = new HashMap<String, String>();
map1.put("key3", "value3");
listOfMaps.add(map1);
listOfMaps.add(map2);
listOfMaps.add(map3);
String keyToSearch = "key2";
for (Map<String, String> map : listOfMaps) {
for (String key : map.keySet()) {
if (keyToSearch.equals(key)) {
System.out.println("Found : " + key + " / value : " + map.get(key));
}
}
}
}
乾杯!
于 2012-07-10T20:18:00.350 に答える
2
Object myObj;
Object myKey;
//Traverse the list
for(HashMap curMap : listOfMaps){
//If this map has the object, that is the key doesn't return a null object
if( (myObj = curMap.get(myKey)) != null) {
//Stop traversing because we are done
break;
}
}
//Act on the object
if(myObj != null) {
//TODO: Do your logic here
}
オブジェクトの代わりにマップへの参照を取得しようとしている場合(何らかの理由で)、マップへの参照を保存することを除いて、同じプロセスが適用されます。
Map myMap;
Object myKey;
//Traverse the list
for(HashMap curMap : listOfMaps){
//If this map has the object, that is the key doesn't return a null object
if(curMap.get(myKey) != null) {
//Store instance to the map
myMap = curMap;
//Stop traversing because we are done
break;
}
}
//Act on the map
if(myMap != null) {
//TODO: Do your logic here
}
于 2012-07-10T20:18:11.800 に答える
1
HashMapのリストでキーを検索するために、以下の改善されたコードを試してください。
public static boolean searchInMap(String keyToSearch)
{
boolean returnVal = false;
List<Map<String, String>> listOfMaps = new ArrayList<Map<String, String>>();
Map<String, String> map1 = new HashMap<String, String>();
map1.put("key1", "value1");
Map<String, String> map2 = new HashMap<String, String>();
map1.put("key2", "value2");
Map<String, String> map3 = new HashMap<String, String>();
map1.put("key3", "value3");
listOfMaps.add(map1);
listOfMaps.add(map2);
listOfMaps.add(map3);
for (Map<String, String> map : listOfMaps)
{
if(map.containsKey(keyToSearch))
{
returnVal =true;
break;
}
}
return returnVal;
}
于 2012-12-24T08:51:31.200 に答える
0
ループを使用せずに配列リスト内のハッシュマップを検索するために使用した効率的な方法。ループは実行時間を長くするので
try{
int index = list.indexOf(map); // map is your map to find in ArrayList
if(index>=0){
HashMap<String, String> map = array_list.get(index);
// Here you can get your values
}
}
catch(Exception e){
e.printStackTrace();
Log.i("HashMap","Not Found");
}
于 2012-08-31T08:05:53.277 に答える
0
ArrayList <HashMap <String、String >>のようなArrayListが あり、HashMap内の値の1つを比較したい場合は、このコードを試してください。
アラーム通知の設定を比較するために使用します。
for (HashMap<String, String> map : AlarmList) {
for (String key : map.keySet())
{
if (key.equals("SendungsID"))
{
if(map.get(key).equals(alarmMap.get("AlarmID")))
{
//found this value in ArrayList
}
}
}
}
于 2013-06-20T10:26:23.943 に答える