我正在尝试使用gson解析JSON对象:
1 st ,2 nd ,3 rd ,4 th
Gson gson=new Gson();
Map<String, HashSet<String>> map = new HashMap<String, HashSet<String>>();
map = (Map<String, HashSet<String>>) gson.fromJson(jsonTxt, map.getClass());
这就是JSON的样子:
"{
\"Rao\":[\"Q7293658\",\"\",\"Q7293657\",\"Q12953055\",\"Q3531237\",\"Q4178159\",\"Q1138810\",\"Q579515\",\"Q3365064\",\"Q7293664\",\"Q1133815\"],
\"Hani Durzy\":[\"\"],
\"Louise\":[\"\",\"Q1660645\",\"Q130413\",\"Q3215140\",\"Q152779\",\"Q233203\",\"Q7871343\",\"Q232402\",\"Q82547\",\"Q286488\",\"Q156723\",\"Q3263649\",\"Q456386\",\"Q233192\",\"Q14714149\",\"Q12125864\",\"Q57669\",\"Q168667\",\"Q141410\",\"Q166028\"],
\"Reyna\":[\"Q7573462\",\"Q2892895\",\"Q363257\",\"Q151944\",\"Q3740321\",\"Q2857439\",\"Q1453358\",\"Q7319529\",\"Q733716\",\"Q16151941\",\"Q7159448\",\"Q5484172\",\"Q6074271\",\"Q1753185\",\"Q7319532\",\"Q5171205\",\"Q3183869\",\"Q1818527\",\"Q251862\",\"Q3840414\",\"Q5271282\",\"Q5606181\"]
}"
我一直收到错误:
Expected BEGIN_OBJECT but was STRING at line 1 column 2
我不认为它与"
开头的事实有关,正如他们在this question中所建议的那样,因为当我删除了第一个和最后一个引号时,我得到了错误Expected name at line 2 column 3
我的完整代码是here on my github page,它很短。
我基本上试图扭转this procedure。 This是一个相关问题。
File f = new File("/home/matthias/Workbench/SUTD/nytimes_corpus/wdtk-parent/wdtk-examples/JSON_Output/user.json");
String jsonTxt = null;
if (f.exists())
{
InputStream is = new FileInputStream("/home/matthias/Workbench/SUTD/nytimes_corpus/wdtk-parent/wdtk-examples/JSON_Output/user.json");
jsonTxt = IOUtils.toString(is);
}
Gson json = new Gson();
Map<String, HashSet<String>> map = new HashMap<String, HashSet<String>>();
map = (Map<String, HashSet<String>>) json.fromJson(jsonTxt, map.getClass());
System.out.println(map);
答案 0 :(得分:1)
根据您所面临的错误,您需要从Json字符串中删除secondDictionary = {"A" : 3, "B" : 47}
,以便gson正确解析它。
例如,对于你的json字符串,更正的字符串是:
"
答案 1 :(得分:1)
试试这个
public class JsonTest {
private String jsonTxt = "{\"Rao\":[\"Q7293658\",\"\",\"Q7293657\",\"Q12953055\",\"Q3531237\","
+ "\"Q4178159\",\"Q1138810\",\"Q579515\",\"Q3365064\",\"Q7293664\",\"Q1133815\"],"
+ "\"Hani Durzy\":[\"\"],\"Louise\":[\"\",\"Q1660645\",\"Q130413\",\"Q3215140\","
+ "\"Q152779\",\"Q233203\",\"Q7871343\",\"Q232402\",\"Q82547\",\"Q286488\","
+ "\"Q156723\",\"Q3263649\",\"Q456386\",\"Q233192\",\"Q14714149\",\"Q12125864\""
+ ",\"Q57669\",\"Q168667\",\"Q141410\",\"Q166028\"],\"Reyna\":[\"Q7573462\","
+ "\"Q2892895\",\"Q363257\",\"Q151944\",\"Q3740321\",\"Q2857439\",\"Q1453358\","
+ "\"Q7319529\",\"Q733716\",\"Q16151941\",\"Q7159448\",\"Q5484172\",\"Q6074271\""
+ ",\"Q1753185\",\"Q7319532\",\"Q5171205\",\"Q3183869\",\"Q1818527\",\"Q251862\","
+ "\"Q3840414\",\"Q5271282\",\"Q5606181\"]}";
@SuppressWarnings("unchecked")
@Test
public void testJson() {
Gson json = new Gson();
Map<String, HashSet<String>> map = new HashMap<String, HashSet<String>>();
map = (Map<String, HashSet<String>>) json.fromJson(jsonTxt, map.getClass());
System.out.println(map);
}
}
输出
{
Reyna=[Q7573462, Q2892895, Q363257, Q151944, Q3740321, Q2857439, Q1453358, Q7319529, Q733716, Q16151941, Q7159448, Q5484172, Q6074271, Q1753185, Q7319532, Q5171205, Q3183869, Q1818527, Q251862, Q3840414, Q5271282, Q5606181],
Rao=[Q7293658, , Q7293657, Q12953055, Q3531237, Q4178159, Q1138810, Q579515, Q3365064, Q7293664, Q1133815],
Louise=[, Q1660645, Q130413, Q3215140, Q152779, Q233203, Q7871343, Q232402, Q82547, Q286488, Q156723, Q3263649, Q456386, Q233192, Q14714149, Q12125864, Q57669, Q168667, Q141410, Q166028],
Hani Durzy=[]
}
从更新,我明白你试图从文件中读取JSON。我有我的版本从文件中读取JSON。检查一下。
private static JsonObject chartJson;
public static String readChartJsonFromJsonFile(String fileName) {
try {
JsonParser jsonParser = new JsonParser();
// get json as buffer
BufferedReader br = new BufferedReader(new FileReader(fileName));
JsonElement element = jsonParser.parse(br);
if (!(element instanceof JsonNull)) {
chartJson = (JsonObject) element;
}
} catch (FileNotFoundException e) {
LoggerManager.fatal("Error reading JSON from file.", JsonFileParser.class.getName());
}
return chartJson.toString();
}
我在文件中的示例JSON:
{
"xArray":[
"1 Jan 2008",
"1 Jan 2009",
"1 Jan 2010",
"1 Jan 2011",
"1 Jan 2012",
"1 Jan 2013",
"1 Jan 2014"
],
"yArray":[
"38",
"87",
"45",
"25",
"67",
"-37",
"98"
]
}
答案 2 :(得分:1)
您已经转义了所有"
个字符,并将整个JSON包装在引号中,就好像这是代码中的String
常量(也许它曾经存在于某个点)。但是你的JsonMapFileExample
正在从磁盘上的文件中读取这个JSON - 没有理由在专用的JSON文件中转义引号。
尝试删除每个键和值周围的"
个字符和 \
转义符。您还可以将JSON直接粘贴到任意数量的在线JSON validators中以进行复核。您的文件内容应该是有效的JSON;你粘贴的不是。