web-dev-qa-db-ja.com

Java:HashMap <String、Object>を配列に変換する方法

HashMap<String, Object>を配列に変換する必要があります。誰がそれがどのように行われたかを教えてもらえますか?

104
burntsugar
 hashMap.keySet().toArray(); // returns an array of keys
 hashMap.values().toArray(); // returns an array of values

編集

両方の配列の順序が同じでない場合があることに注意してください。キー/値のペアが必要な場合の反復のより良いアプローチについては、oxbow_lakesの回答を参照してください。

180
Landon Kuhn

キーと値が必要な場合は、entrySetを使用していつでも実行できます。

hashMap.entrySet().toArray(); // returns a Map.Entry<K,V>[]

各エントリから、(もちろん)getKeyメソッドとgetValueメソッドを介してキーand値の両方を取得できます。

60
oxbow_lakes

HashMap<String, SomeObject> hashMapがある場合

hashMap.values().toArray();

object []を返します。代わりにSomeObject型の配列が必要な場合は、次を使用できます。

hashMap.values().toArray(new SomeObject[0]);

48
kmccoy

キーと値の各配列の正しい順序を保証するには、これを使用します(他の回答では、順序に関する保証がない個別のSetsを使用します。

Map<String, Object> map = new HashMap<String, Object>();
String[] keys = new String[map.size()];
Object[] values = new Object[map.size()];
int index = 0;
for (Map.Entry<String, Object> mapEntry : map.entrySet()) {
    keys[index] = mapEntry.getKey();
    values[index] = mapEntry.getValue();
    index++;
}
30
CrackerJack9

HashMapに順序を維持させたい場合は、代わりにLinkedHashMapを使用することを検討できます。私の知る限り、その機能はHashMapと同じですが、FIFOであるため、アイテムが追加された順序を維持します。

12
Dean Wild
Map<String, String> map = new HashMap<String, String>();
map.put("key1", "value1");
map.put("key2", "value2");

Object[][] twoDarray = new Object[map.size()][2];

Object[] keys = map.keySet().toArray();
Object[] values = map.values().toArray();

for (int row = 0; row < twoDarray.length; row++) {
    twoDarray[row][0] = keys[row];
    twoDarray[row][1] = values[row];
}

// Print out the new 2D array
for (int i = 0; i < twoDarray.length; i++) {
    for (int j = 0; j < twoDarray[i].length; j++) {
        System.out.println(twoDarray[i][j]);
    }
}
6
valerian

@kmccoyとほぼ同じものを使用しましたが、keySet()の代わりにこれを行いました

hashMap.values().toArray(new MyObject[0]);
6
Hugo Tavares

1次元配列を取得します。

    String[] arr1 = new String[hashmap.size()];
    String[] arr2 = new String[hashmap.size()];
    Set entries = hashmap.entrySet();
    Iterator entriesIterator = entries.iterator();

    int i = 0;
    while(entriesIterator.hasNext()){

        Map.Entry mapping = (Map.Entry) entriesIterator.next();

        arr1[i] = mapping.getKey().toString();
        arr2[i] = mapping.getValue().toString();

        i++;
    }


2次元配列を取得します。

   String[][] arr = new String[hashmap.size()][2];
   Set entries = hashmap.entrySet();
   Iterator entriesIterator = entries.iterator();

   int i = 0;
   while(entriesIterator.hasNext()){

    Map.Entry mapping = (Map.Entry) entriesIterator.next();

    arr[i][0] = mapping.getKey().toString();
    arr[i][1] = mapping.getValue().toString();

    i++;
}
3

Java 8+を使用しており、おそらくTestNGデータプロバイダー用に2次元Arrayが必要な場合は、以下を試すことができます。

map.entrySet()
    .stream()
    .map(e -> new Object[]{e.getKey(), e.getValue()})
    .toArray(Object[][]::new);

ObjectsがStringsであり、String[][]が必要な場合は、以下を試してください。

map.entrySet()
    .stream()
    .map(e -> new String[]{e.getKey(), e.getValue().toString()})
    .toArray(String[][]::new);
2
Graham Russell

これも試してみてください。

public static String[][] getArrayFromHash(Hashtable<String,String> data){
        String[][] str = null;
        {
            Object[] keys = data.keySet().toArray();
            Object[] values = data.values().toArray();
            str = new String[keys.length][values.length];
            for(int i=0;i<keys.length;i++) {
                str[0][i] = (String)keys[i];
                str[1][i] = (String)values[i];
            }
        }
        return str;
    }

ここでは、戻り値の型として文字列を使用しています。必要な戻り値の型に変更できます。

0
Mayur
@SuppressWarnings("unchecked")
    public static <E,T> E[] hashMapKeysToArray(HashMap<E,T> map)
    {
        int s;
        if(map == null || (s = map.size())<1)
            return null;

        E[] temp;
        E typeHelper;
        try
        {
            Iterator<Entry<E, T>> iterator = map.entrySet().iterator();
            Entry<E, T> iK = iterator.next();
            typeHelper = iK.getKey();

            Object o = Array.newInstance(typeHelper.getClass(), s);
            temp = (E[]) o;

            int index = 0;
            for (Map.Entry<E,T> mapEntry : map.entrySet())
            {
                temp[index++] = mapEntry.getKey();
            }
        }
        catch (Exception e)
        {
            return null;
        }
        return temp;
    }
//--------------------------------------------------------
    @SuppressWarnings("unchecked")
    public static <E,T> T[] hashMapValuesToArray(HashMap<E,T> map)
    {
        int s;
        if(map == null || (s = map.size())<1)
            return null;

        T[] temp;
        T typeHelper;
        try
        {
            Iterator<Entry<E, T>> iterator = map.entrySet().iterator();
            Entry<E, T> iK = iterator.next();
            typeHelper = iK.getValue();

            Object o = Array.newInstance(typeHelper.getClass(), s);
            temp = (T[]) o;

            int index = 0;
            for (Map.Entry<E,T> mapEntry : map.entrySet())
            {
                temp[index++] = mapEntry.getValue();
            }
        }
        catch (Exception e)
        {return null;}

        return temp;
    }
0
Ali Bagheri
HashMap<String, String> hashMap = new HashMap<>();
String[] stringValues= new String[hashMap.values().size()];
hashMap.values().toArray(stringValues);
0