如何解析字符串转换成地图

问题描述:

有一个像A = B & C = d & E = F,如何辨别它解析为地图的字符串?如何解析字符串转换成地图

我会用分裂

String text = "A=B&C=D&E=F"; 
Map<String, String> map = new LinkedHashMap<String, String>(); 
for(String keyValue : text.split(" *& *")) { 
    String[] pairs = keyValue.split(" *= *", 2); 
    map.put(pairs[0], pairs.length == 1 ? "" : pairs[1]); 
} 

EDIT允许填充空间,并与=或没有的值。例如

A = minus- & C=equals= & E==F 
+2

+1。在编写相同的代码的过程中。部分取决于检查代码需要做多少错误。这是玩具代码吗?这是否需要复制严重形成的输入等?这里代码会给arrayIndexException如果没有“=”的例子,但可能是在方案中就好了。 – 2011-03-01 10:39:59

+0

它将处理的'='中的值,而不是斩波其关闭;) – 2011-03-01 10:42:56

+0

@汤姆,谢谢,增加了一些错误处理。 – 2011-03-01 10:45:50

String t = A=B&C=D&E=F; 
Map map = new HashMap(); 
String[] pairs = t.split("&"); 
//TODO 1) Learn generis 2) Use gnerics  
for (String pair : pairs) 
{ 
    String[] kv = pair.split("="); 
    map.put(kv[0], kv[1]); 
} 

分割字符串(使用一个或StringTokenizerString.split())上 '&'。在每个令牌上再次分开'='。使用第一部分作为键,第二部分作为值。

它也可以使用正则表达式来完成,但问题是真正为StringTokenizer很简单。

public class TestMapParser { 
    @Test 
    public void testParsing() { 
     Map<String, String> map = parseMap("A=B&C=D&E=F"); 
     Assert.assertTrue("contains key", map.containsKey("A")); 
     Assert.assertEquals("contains value", "B", map.get("A")); 

     Assert.assertTrue("contains key", map.containsKey("C")); 
     Assert.assertEquals("contains value", "D", map.get("C")); 

     Assert.assertTrue("contains key", map.containsKey("E")); 
     Assert.assertEquals("contains value", "F", map.get("E")); 
    } 

    private Map<String, String> parseMap(final String input) { 
     final Map<String, String> map = new HashMap<String, String>(); 
     for (String pair : input.split("&")) { 
      String[] kv = pair.split("="); 
      map.put(kv[0], kv[1]); 
     } 
     return map; 
    } 
} 

只是用番石榴分配器

String src="A=B&C=D&E=F"; 
Map map= Splitter.on('&').withKeyValueSeparator('=').split(src);