1

LinkedHashMap をキーで表形式で出力するためのより良いアルゴリズムを探しています。ここでシナリオを説明しますが、

//hashmap goes like this
LinkedHashMap<String , ArrayList<String>> hash=new LinkedHashMap<String,ArrayList<String>>();

// put some values in some arraylist
ArrayList<String> value1=Arrays.asList("s1", "s2", "s3");
ArrayList<String> value2=Arrays.asList("s4", "s5", "s6");
ArrayList<String> value1=Arrays.asList("s7", "s8", "s9");

// put values in hashmap
hash.put("key1",value1);
hash.put("key2",value2);
hash.put("key3",value3);

さて、出力がhtml表のようになるといいのですが。

key1 key2 key3

s1    s4   s7

s2    s5   s6

s3    s6   s9

これを行う良い方法は何ですか?ありがとう 。

4

3 に答える 3

1

JSPページを使用している場合は、これを試してください

LinkedHashMap> hash = new LinkedHashMap>();

// put some values in some arraylist
ArrayList<String> value1=Arrays.asList("s1", "s2", "s3");
ArrayList<String> value2=Arrays.asList("s4", "s5", "s6"); 
ArrayList<String> value1=Arrays.asList("s7", "s8", "s9");

// put values in hashmap
hash.put("key1",value1);
hash.put("key2",value2);
hash.put("key3",value3);

<% 
  for(Entry<String, ArrayList<String>> en: hash.entrySet()) {
      %>
   <td> 
     <% en.getKey(); %>
   </td>
 <%  }
 %>
 </td>
  </tr>

JSTLタグを使用してこれを行うこともできます。

于 2012-09-22T08:12:03.113 に答える
1

試す、

 StringBuffer sb=new StringBuffer();
 sb.append("<tr>");
 sb.append("<td>" + hash.get("key1").get(0) + "</td>");
 sb.append("<td>" + hash.get("key2").get(0) + "</td>");
 sb.append("<td>" + hash.get("key3").get(0) + "</td>");
 sb.append("</tr>");
于 2012-09-22T08:13:54.137 に答える
1

次のコードは実行する必要があります

public static void main(String[] args) {
        // hashmap goes like this
        LinkedHashMap<String, List<String>> hash = new LinkedHashMap<String, List<String>>();

        // put some values in some arraylist
        List<String> value1 = (List<String>) Arrays.asList("s1", "s2", "s3");
        List<String> value2 = (List<String>) Arrays.asList("s4", "s5", "s6");
        List<String> value3 = (List<String>) Arrays.asList("s7", "s8", "s9");

        // put values in hashmap
        hash.put("key1", value1);
        hash.put("key2", value2);
        hash.put("key3", value3);

        int count = 0;
        boolean exit = false;
        while (!exit) {
            for (String key : hash.keySet()) {
                String value = hash.get(key).get(count);
                System.out.printf("\t" + value);
            }
            System.out.printf("\n");
            count++;
            if (count == hash.get("key1").size()) {
                exit = true;
            }
        }

    }

そして、以下は必要に応じた出力です。

s1  s4  s7
s2  s5  s8
s3  s6  s9
于 2012-09-22T08:19:46.643 に答える