如何解析字符串转换成地图
答
我会用分裂
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
答
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]);
}
答
分割字符串(使用一个或StringTokenizer
String.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);
+1。在编写相同的代码的过程中。部分取决于检查代码需要做多少错误。这是玩具代码吗?这是否需要复制严重形成的输入等?这里代码会给arrayIndexException如果没有“=”的例子,但可能是在方案中就好了。 – 2011-03-01 10:39:59
它将处理的'='中的值,而不是斩波其关闭;) – 2011-03-01 10:42:56
@汤姆,谢谢,增加了一些错误处理。 – 2011-03-01 10:45:50