Разбор ответа JSON, который имеет только «строки» и «столбцы» для POJO - PullRequest
0 голосов
/ 12 апреля 2020

Можно ли проанализировать JSON ответ на POJO, даже если ответ отправляет только строки и столбцы?

Я получаю этот ответ от API:

{
"rows": [
[
  "FIRST NATIONAL BANK OF OMAHA",
  36644,
  "COM",
  44527,
  198809,
  "SH",
  -1.5631,
  "Put",
  "2019-09-30"
],
[
  "WAYNE HUMMER INVESTMENTS L.L.C.",
  49096,
  "COM",
  17975,
  90817,
  "SH",
  2.8971,
  "Put",
  "2019-06-30"
]
],
"columns": [
"Institution Name",
"Institution CIK",
"Class of Security Held",
"Value of Security Held",
"Volume of Security Held",
"Type of Security Held",
"Quarterly Change in Security Held",
"Put/Call",
"Report Date"
]
}

Это код, который я использую, сокращенно для краткости, чтобы подключиться к API и получить ответ JSON, который я передаю через класс десериализатора с помощью Gson:

public static void requestResponse(){

   URL apiURL = new URL("http://apilink.com/api/getSomething.json?T=gnbuweiogh9y89234y&symbol=GOOG");

   String readLine = null;

   HttpConnection apiConnection =  (HttpConnection) apiURL.openConnection();

   apiConnection.setRequestMethod("GET");

   int responseCode = apiConnection.getResponseCode();

   if(responseCode == HttpConnection.HTTP_OK) {

       BufferedReader in = new BufferedReader(new InputStreamReader(apiConnection.getInputStream()));

       StringBuffer response = new StringBuffer();

       while((readLine = in.readLine()) != null) {
           response.append(readLine);
       }
       in.close();

       String jsonResponse = response.toString();

       Deserializer deSerializer = new Gson().fromJson(jsonResponse, Deserializer .class);
       List<String> columns = deSerializer.getColumns;
       // Do something with the data
   }
}

Это класс десериализации, который я сделал:

public class deSerializer {

@SerializedName("rows")
@Expose
private List<List<String>> rows = null;
@SerializedName("columns")
@Expose
private List<String> columns = null;

public List<List<String>> getRows() {
return rows;
}

public void setRows(List<List<String>> rows) {
this.rows = rows;
}

public List<String> getColumns() {
return columns;
} 

public void setColumns(List<String> columns) {
this.columns = columns;
}

}

Я ожидал, что ответ JSON будет в таком формате, который упростил бы сериализацию:

{
 "data": [{
"Institution Name": "FIRST NATIONAL BANK OF OMAHA",
"Institution CIK": 36644,
"Class of Security Held": "COM",
"Value of Security Held": 44527
 } ]
}

Извините за длинный пост, но что будет лучший подход для десериализации ответа на POJO?

Большое спасибо.

1 Ответ

1 голос
/ 12 апреля 2020

Вы можете преобразовать его в нужный вам формат, добавив следующий вспомогательный метод в ваш deSerializer класс:

public List<Map<String, Object>> asListOfMaps() {
    List<Map<String, Object>> list = new ArrayList<>(this.rows.size());
    for (List<Object> data : this.rows) {
        Map<String, Object> row = new LinkedHashMap<>(this.columns.size());
        for (int i = 0; i < this.columns.size(); i++)
            row.put(this.columns.get(i), data.get(i));
        list.add(row);
    }
    return list;
}
...