2016-05-30 17 views
0

配列の配列を解析する必要があります。ここで は私の現在のコードです:Jackson:配列の配列を解析する

chartList: [ array of chartEntries ] 

package android.app; 

import android.support.annotation.Nullable; 

import com.fasterxml.jackson.annotation.JsonCreator; 
import com.fasterxml.jackson.core.JsonParser; 
import com.fasterxml.jackson.core.JsonProcessingException; 
import com.fasterxml.jackson.core.JsonToken; 
import com.fasterxml.jackson.databind.DeserializationConfig; 
import com.fasterxml.jackson.databind.DeserializationContext; 
import com.fasterxml.jackson.databind.JsonDeserializer; 
import com.fasterxml.jackson.databind.ObjectMapper; 
import com.fasterxml.jackson.databind.annotation.JsonDeserialize; 
import com.fasterxml.jackson.databind.type.TypeFactory; 

import java.io.IOException; 
import java.util.ArrayList; 
import java.util.Arrays; 
import java.util.Iterator; 
import java.util.List; 

/** 
*/ 
public class ChartData { 
    private static final String MSFT_JSON = "[[\"2015-05-27\",47.61,27335600]]"; 
    private static final ObjectMapper mapper = new ObjectMapper(); 

    @Nullable 
    public static ChartList msftPrice() { 
     try { 
      ChartList[] chartList = mapper.readValue(MSFT_JSON, ChartList[].class); 
      // ChartEntry[] chartEntries = mapper.convertValue(MSFT_JSON, ChartEntry[].class); 
      return null; 
     } catch (IOException e) { 
      e.printStackTrace(); 
     } 
     return null; 
    } 

    @JsonDeserialize(using = ChartEntryDeserializer.class) 
    public static class ChartEntry { 
     public String date; 
     public Float price; 
     public Integer volume; 

     public ChartEntry(String date, Float price, Integer volume) { 
      this.date = date; 
      this.price = price; 
      this.volume = volume; 
     } 
    } 

    private static class ChartEntryDeserializer extends JsonDeserializer<ChartEntry> { 
     public ChartEntryDeserializer() { 
     } 

     @Override @JsonCreator 
     public ChartEntry deserialize(JsonParser p, DeserializationContext ctxt) throws IOException, JsonProcessingException { 
      String date = p.getCodec().readValue(p, String.class); 
      Float price = p.getCodec().readValue(p, Float.class); 
      Integer volume = p.getCodec().readValue(p, Integer.class); 

      return new ChartEntry(date, price, volume); 
     } 
    } 

    @JsonDeserialize(using=ChartListDeserializer.class) 
    public static class ChartList { 
     public ChartEntry[] chartEntries; 
    } 

    private static class ChartListDeserializer extends JsonDeserializer<ChartList> { 
     @Override 
     public ChartList deserialize(JsonParser p, DeserializationContext ctxt) throws IOException, JsonProcessingException { 
      ChartList result = new ChartList(); 
      result.chartEntries = p.readValuesAs(ChartEntry[].class).next(); 
      return result; 
     } 
    } 
} 

それは

chartList array of type ChartList [ 
    0: { chartEntries: [ChartEntry object] 
] 

のようなリターンの何かがどのように私はそれがより多くのようになり平らに作ることができるのでしょうか?

答えて

1

まず、データモデルを使用コードから分離する必要があります。私はJUnitテストでこれを使って、使い方を説明しました。データモデルは、ChartListとChartEntryという2つの別々のクラスに分割されています。

結果のJSON文字列は次のようになります。

{"chartList":[{"date":"2015-05-27","price":47.61,"volume":27335600},{"date":"2015-05-28","price":47.71,"volume":27335700}]} 

ここでテストクラス

import static org.junit.Assert.assertEquals; 
import org.junit.Test; 
import com.fasterxml.jackson.databind.ObjectMapper; 

public class TestClass { 

    private static final ObjectMapper mapper = new ObjectMapper(); 

    @Test 
    public void testObjToJson() throws Exception { 
     ChartList list = new ChartList(); 
     list.addEntry(new ChartEntry("2015-05-27", 47.61f, 27335600)); 
     list.addEntry(new ChartEntry("2015-05-28", 47.71f, 27335700)); 
     System.out.println(mapper.writeValueAsString(list)); 
    } 

    @Test 
    public void testJsonToObj() throws Exception { 
     final String JSON = "{\"chartList\":[{\"date\":\"2015-05-27\",\"price\":47.61,\"volume\":27335600},{\"date\":\"2015-05-28\",\"price\":47.71,\"volume\":27335700}]}"; 
     ChartList list = mapper.readValue(JSON, ChartList.class); 
     assertEquals(2, list.getChartList().size()); 
    } 
} 

がChartListがChartEntryこの

のように見えるこの

import java.util.ArrayList; 
import java.util.List; 

import com.fasterxml.jackson.annotation.JsonIgnore; 

public class ChartList { 

    private List<ChartEntry> chartList = new ArrayList<>(); 

    @JsonIgnore 
    public void addEntry(ChartEntry entry) { 
     chartList.add(entry); 
    } 

    public List<ChartEntry> getChartList() { 
     return chartList; 
    } 

    public void setChartList(List<ChartEntry> chartList) { 
     this.chartList = chartList; 
    } 
} 

のように見えるのです

public class ChartEntry { 

    private String date; 
    private Float price; 
    private Integer volume; 

    public ChartEntry() { 
     // Needed for JSON-to-Object parsing 
    } 

    public ChartEntry(String date, Float price, Integer volume) { 
     this.date = date; 
     this.price = price; 
     this.volume = volume; 
    } 

    public String getDate() { 
     return date; 
    } 

    public void setDate(String date) { 
     this.date = date; 
    } 

    public Float getPrice() { 
     return price; 
    } 

    public void setPrice(Float price) { 
     this.price = price; 
    } 

    public Integer getVolume() { 
     return volume; 
    } 

    public void setVolume(Integer volume) { 
     this.volume = volume; 
    } 
} 
+0

ありがとうございます。私はjson入力文字列の形式を変更できません。私は構文解析の結果を平らにすることが可能かどうか尋ねた。 – edbond