繁体   English   中英

如何从此JSON提取数据?

[英]How to extract data from this JSON?

我将以下JSON数组作为这样的字符串,

String output = "[{\"Symbol\":\"AMZN\",\"Name\":\"Amazon.com Inc\",\"Exchange\":\"NASDAQ\"},{\"Symbol\":\"VXAZN\",\"Name\":\"CBOE Amazon VIX Index\",\"Exchange\":\"Market Data Express\"}]";

我想解析它并制作一个像这样的字符串数组,

array = {"AMZN Amazon.com Inc NASDAQ", "VXAZN CBOE Amazon VIX Index Market Data Express"};

我想出了以下代码,使用json-simple-1.1.1.jar库将字符串解析为JSON数组,

import org.json.simple.*;
import org.json.simple.parser.JSONParser;
import org.json.simple.parser.ParseException;


public class RESTclient {

    public static void main(String[] args) {

            String output = "[{\"Symbol\":\"AMZN\",\"Name\":\"Amazon.com Inc\",\"Exchange\":\"NASDAQ\"},{\"Symbol\":\"VXAZN\",\"Name\":\"CBOE Amazon VIX Index\",\"Exchange\":\"Market Data Express\"}]";

            JSONParser parser = new JSONParser();

            JSONArray jsonArray = null;

            try {
                jsonArray = (JSONArray) parser.parse(output);
            } catch (ParseException e) {
                e.printStackTrace();
            }

            System.out.println(jsonArray);
        }
}

这给了我以下输出

[{"Name":"Amazon.com Inc","Exchange":"NASDAQ","Symbol":"AMZN"},{"Name":"CBOE Amazon VIX Index","Exchange":"Market Data Express","Symbol":"VXAZN"}]

在此之后,是否有一种优雅的方法来实现所需的输出?

您必须编写额外的代码。

ArrayList<String> stringArray = new ArrayList<String>();
for (Iterator iterator = jsonArray.iterator(); iterator.hasNext();) {
    JSONObject map = (JSONObject)iterator.next();
    stringArray.add(map.get("Symbol")+" "+map.get("Name")+" "+map.get("Exchange"));
}
//stringArray is want you want

你可以像杰克逊那样,

    private ObjectMapper    mapper  = new ObjectMapper();
    String[] outputArray = mapper.readValue(jsonString, String[].class); 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM