web-dev-qa-db-ja.com

TreeMapを反復処理する方法は?

可能性のある複製:
マップ内の各エントリを反復処理するにはどうすればよいですか

TreeMapを反復処理し、特定の値を持つすべてのキーについて、それらを新しいTreeMapに追加する必要があります。これどうやってするの?

127
Click Upvote

タイプTreeMap <String、Integer>を想定:

for(Map.Entry<String,Integer> entry : treeMap.entrySet()) {
  String key = entry.getKey();
  Integer value = entry.getValue();

  System.out.println(key + " => " + value);
}

(キーと値のタイプはもちろん任意のクラスにできます)

213
Zed
    //create TreeMap instance
    TreeMap treeMap = new TreeMap();

    //add key value pairs to TreeMap
    treeMap.put("1","One");
    treeMap.put("2","Two");
    treeMap.put("3","Three");

    /*
      get Collection of values contained in TreeMap using
      Collection values()        
    */
    Collection c = treeMap.values();

    //obtain an Iterator for Collection
    Iterator itr = c.iterator();

    //iterate through TreeMap values iterator
    while(itr.hasNext())
      System.out.println(itr.next());

または:

   for (Map.Entry<K,V> entry : treeMap.entrySet()) {
        V value = entry.getValue();
        K key = entry.getKey();
   }

または:

   // Use iterator to display the keys and associated values
   System.out.println("Map Values Before: ");
   Set keys = map.keySet();
   for (Iterator i = keys.iterator(); i.hasNext();) {
     Integer key = (Integer) i.next();
     String value = (String) map.get(key);
     System.out.println(key + " = " + value);
   }
25
karim79

任意のマップを反復処理する一般的な方法を指摘するだけです。

 private <K, V> void iterateOverMap(Map<K, V> map) {
    for (Map.Entry<K, V> entry : map.entrySet()) {
        System.out.println("key ->" + entry.getKey() + ", value->" + entry.getValue());
    }
    }
5
Priyank Doshi

Google Collections を使用して、Kがキータイプであると仮定します。

Maps.filterKeys(treeMap, new Predicate<K>() {
  @Override
  public boolean apply(K key) {
    return false; //return true here if you need the entry to be in your new map
  }});

値も必要な場合は、代わりにfilterEntriesを使用できます。

1
Jorn