gson + json配对错误

时间:2015-04-28 05:08:50

标签: java json gson

我正在尝试使用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 procedureThis是一个相关问题。

更新

        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);

3 个答案:

答案 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;你粘贴的不是。