Как преобразовать произвольный JSON в пригодную для использования структуру в Java

Я пытаюсь использовать gson для преобразования этого возвращенного JSON в какой-то структуру данных, чтобы я мог извлечь полезные данные.

Например:

http://search.twitter.com/search.json?q=test&rpp=1

Возвращает:

{
    "completed_in":0.028,
    "max_id":196386333906837504,
    "max_id_str":"196386333906837504",
    "next_page":"?page=2&max_id=196386333906837504&q=test&rpp=1",
    "page":1,
    "query":"test",
    "refresh_url":"?since_id=196386333906837504&q=test",
       "results":[
          {
             "created_at":"Sat, 28 Apr 2012 23:52:05 +0000",
             "from_user":"della_ky",
             "from_user_id":525641596,
             "from_user_id_str":"525641596",
             "from_user_name":"kydella modeste",
             "geo":null,
             "id":196386333906837504,
             "id_str":"196386333906837504",
             "iso_language_code":"en",
             "metadata":{
                "result_type":"recent"
             },
             "profile_image_url":"http:\/\/a0.twimg.com\/profile_images\/2159990525\/webcam-toy-photo3_20_2__normal.jpg",
             "profile_image_url_https":"https:\/\/si0.twimg.com\/profile_images\/2159990525\/webcam-toy-photo3_20_2__normal.jpg",
             "source":"<a href="http:\/\/mobile.twitter.com" rel="nofollow">Mobile Web<\/a>",
             "text":"RT @Y__U__NOOO: #SongsIKnowOffByHeart ALL SONGS I LISTEN TO. BRAIN, Y U NO REMEMBER TEST ANSWERS LIKE THAT?!?",
             "to_user":null,
             "to_user_id":null,
             "to_user_id_str":null,
             "to_user_name":null
          }
       ],
       "results_per_page":1,
       "since_id":0,
       "since_id_str":"0"
    }

В конечном счете, я хотел бы иметь возможность вывести список твитов с имя отправителя и дату/время твита.

Я прочитал документацию по gson, но не могу понять если честно -для меня появилось много новых концепций.

Нужно ли мне определять класс, который точно соответствует структуре JSON, чтобы затем заполнить экземпляр этого класса? Если это так кажется очень негибким / трудоемким. В идеале я ищу что-то который будет обрабатывать JSON в любой форме и даст мне структуру, которую я могу использовать автоматически...

Кто-нибудь может подсказать? Будучи новичком в этом -, тем более подробно и словами из наименьшего количества слогов, тем лучше!

Обновление -Благодаря ответам, которые я уже получил по этому поводу, я попытался собрать класс, чтобы захватить твиттер JSON. Однако, поскольку в JSON есть встроенный ArrayList of Objects, я немного борюсь... Пока у меня есть

public class tweetData {
    private double completed_in;
    private long max_id;
    private long max_id_str;
    private String next_page;
    private int page;
    private String query;
    private String refresh_url;
    private List tweets = new ArrayList();
}

и

public class tweetDetails {
    private String created_at;
    private String from_user;
    private long from_user_id;
    private long from_user_id_str;
    private String from_user_name;
    private String geo;
    private long id;
    private long id_str;
    private String iso_language_code;
//  "metadata":
//  {
//  "result_type":"recent"
//  },
    private String profile_image_url;
    private String profile_image_url_https;
    private String source;
    private String text;
    private String to_user;
    private String to_user_id;
    private String to_user_id_str;
    private String to_user_name;
}

, которые я создаю с помощью

URI uri = new URI("http", "search.twitter.com", "/search.json", "q="+ searchTerms + "&rrp=" + RRP, null);
URL twitterSearch = uri.toURL();
URLConnection yc = twitterSearch.openConnection();
JsonReader reader = new JsonReader(new InputStreamReader(yc.getInputStream()));
Gson gson = new Gson();
tweetData data = gson.fromJson(reader, tweetData.class);
System.out.println(data);

. Основные значения имени :заполняются правильно, но ArrayList - нет.

tweetData : 0.17196614959919140865196614959919140865?page=2&max_id=196614959919140865&q=test1test?since_id=196614959919140865&q=testSIZE 0[]

Итак, я все еще немного борюсь -буду очень признателен за любые дополнительные советы!

Тиа, Том

11
задан CaptJak 11 February 2016 в 20:51
поделиться