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 回答