在地图中解析带有 key=value 对的字符串?
Parse a string with key=value pair in a map?
我有以下格式为 key1=value1, key2=value2
的字符串,我需要将其加载到地图 (Map<String, String>)
中作为 key=value
,所以我需要用逗号分隔 ,
然后加载 cossn
作为键和 0
它的值。
String payload = "cossn=0, itwrqm=200006033213";
Map<String, String> holder =
Splitter.on(",").trimResults().withKeyValueSeparator("=").split(payload);
我在这里使用 Splitter 来完成这项工作,但在某些情况下它会失败。对于我的一些字符串,值有一些带等号的字符串。所以对于下面的字符串,它对我来说是失败的:
String payload = "cossn=0, abc=hello/=world";
如何让它适用于上述情况?对于上述情况 key
将是 abc
,值应该是 hello/=world
。这可能吗?
您可以添加一个数字来说明您想要拆分多少次,只需添加一个 2 即可拆分
import java.util.HashMap;
public class HelloWorld{
public static void main(String []args){
HashMap<String, String> holder = new HashMap();
String payload = "cossn=0, abc=hello/=world";
String[] keyVals = payload.split(", ");
for(String keyVal:keyVals)
{
String[] parts = keyVal.split("=",2);
holder.put(parts[0],parts[1]);
}
}
}
您可以直接用 Splitter
API 做同样的事情:
Map<String, String> result = Splitter.on(',')
.trimResults()
.withKeyValueSeparator(
Splitter.on('=')
.limit(2)
.trimResults())
.split(input);
我有以下格式为 key1=value1, key2=value2
的字符串,我需要将其加载到地图 (Map<String, String>)
中作为 key=value
,所以我需要用逗号分隔 ,
然后加载 cossn
作为键和 0
它的值。
String payload = "cossn=0, itwrqm=200006033213";
Map<String, String> holder =
Splitter.on(",").trimResults().withKeyValueSeparator("=").split(payload);
我在这里使用 Splitter 来完成这项工作,但在某些情况下它会失败。对于我的一些字符串,值有一些带等号的字符串。所以对于下面的字符串,它对我来说是失败的:
String payload = "cossn=0, abc=hello/=world";
如何让它适用于上述情况?对于上述情况 key
将是 abc
,值应该是 hello/=world
。这可能吗?
您可以添加一个数字来说明您想要拆分多少次,只需添加一个 2 即可拆分
import java.util.HashMap;
public class HelloWorld{
public static void main(String []args){
HashMap<String, String> holder = new HashMap();
String payload = "cossn=0, abc=hello/=world";
String[] keyVals = payload.split(", ");
for(String keyVal:keyVals)
{
String[] parts = keyVal.split("=",2);
holder.put(parts[0],parts[1]);
}
}
}
您可以直接用 Splitter
API 做同样的事情:
Map<String, String> result = Splitter.on(',')
.trimResults()
.withKeyValueSeparator(
Splitter.on('=')
.limit(2)
.trimResults())
.split(input);