как да де-сериализираме JSON данни, в които самият Timestamp съдържа полета?

Не мога да картографирам класа с дадените JSON данни:

{
    "Meta Data": {
        "1. Information": "Intraday (15min) open, high, low, close prices and volume",
        "2. Symbol": "MSFT",
        "3. Last Refreshed": "2018-09-28 15:45:00",
        "4. Interval": "15min",
        "5. Output Size": "Full size",
        "6. Time Zone": "US/Eastern"
    },
    "Time Series (15min)": {
        "2018-09-28 15:45:00": {
            "1. open": "114.2800",
            "2. high": "114.5600",
            "3. low": "114.2400",
            "4. close": "114.4800",
            "5. volume": "2316251"
        },
        "2018-09-28 15:30:00": {
            "1. open": "114.4450",
            "2. high": "114.4500",
            "3. low": "114.2600",
            "4. close": "114.2900",
            "5. volume": "759991"
        },
        "2018-09-28 15:15:00": {
            "1. open": "114.3550",
            "2. high": "114.5200",
            "3. low": "114.3100",
            "4. close": "114.4400",
            "5. volume": "515174"
        }
    }
}

Как да създам структура на класова структура, така че да мога да де-сериализирам горните данни с помощта на newtonsoft в c#?


person Anang Johari    schedule 30.09.2018    source източник
comment
Какво ще кажете за речник, ако приемем, че не можете да имате дубликати?   -  person Llama    schedule 30.09.2018
comment
Трябва ли да считам timestamp(2018-09-28 15:45:00) за име на клас? мисля, че не е добре да се създава клас по времево клеймо.   -  person Anang Johari    schedule 30.09.2018


Отговори (2)


Използвайки помощта на Quicktype и малко редактиране, създадох тези класове:

public class RootObject
{
    [JsonProperty("Meta Data")]
    public MetaData MetaData { get; set; }

    [JsonProperty("Time Series (15min)")]
    public Dictionary<DateTime, TimeSeriesItem> TimeSeries15Min { get; set; }
}

public class MetaData
{
    [JsonProperty("1. Information")]
    public string The1Information { get; set; }

    [JsonProperty("2. Symbol")]
    public string The2Symbol { get; set; }

    [JsonProperty("3. Last Refreshed")]
    public DateTimeOffset The3LastRefreshed { get; set; }

    [JsonProperty("4. Interval")]
    public string The4Interval { get; set; }

    [JsonProperty("5. Output Size")]
    public string The5OutputSize { get; set; }

    [JsonProperty("6. Time Zone")]
    public string The6TimeZone { get; set; }
}

public class TimeSeriesItem
{
    [JsonProperty("1. open")]
    public string The1Open { get; set; }

    [JsonProperty("2. high")]
    public string The2High { get; set; }

    [JsonProperty("3. low")]
    public string The3Low { get; set; }

    [JsonProperty("4. close")]
    public string The4Close { get; set; }

    [JsonProperty("5. volume")]
    public long The5Volume { get; set; }
}

Можете да го десериализирате така:

var data = Newtonsoft.Json.JsonConvert.DeserializeObject<RootObject>(json);

Опитайте онлайн

person Llama    schedule 30.09.2018
comment
Благодаря много .. да, работи добре. :) наистина е полезно за мен, тъй като току-що започнах да работя върху JSON. - person Anang Johari; 30.09.2018

Ето решението, включен тест... Обикновено използвам този Json Class Jenerator за генерирайки класовете, понякога трябва да модифицирате класовете, които извежда, но общо казано, това е доста добро

void Main()
{
    string test = @"{
    ""Meta Data"": {
        ""1. Information"": ""Intraday (15min) open, high, low, close prices and volume"",
        ""2. Symbol"": ""MSFT"",
        ""3. Last Refreshed"": ""2018-09-28 15:45:00"",
        ""4. Interval"": ""15min"",
        ""5. Output Size"": ""Full size"",
        ""6. Time Zone"": ""US/Eastern""
    },
    ""Time Series (15min)"": {
        ""2018-09-28 15:45:00"": {
            ""1. open"": ""114.2800"",
            ""2. high"": ""114.5600"",
            ""3. low"": ""114.2400"",
            ""4. close"": ""114.4800"",
            ""5. volume"": ""2316251""
        },
        ""2018-09-28 15:30:00"": {
            ""1. open"": ""114.4450"",
            ""2. high"": ""114.4500"",
            ""3. low"": ""114.2600"",
            ""4. close"": ""114.2900"",
            ""5. volume"": ""759991""
        },
        ""2018-09-28 15:15:00"": {
            ""1. open"": ""114.3550"",
            ""2. high"": ""114.5200"",
            ""3. low"": ""114.3100"",
            ""4. close"": ""114.4400"",
            ""5. volume"": ""515174""
        }
    }
}";

    JsonConvert.DeserializeObject<Result>(test).Dump();

}

// Define other methods and classes here
public class MetaData
{
    [JsonProperty("1. Information")]
    public string Information { get; set; }

    [JsonProperty("2. Symbol")]
    public string Symbol { get; set; }

    [JsonProperty("3. Last Refreshed")]
    public string LastRefreshed { get; set; }

    [JsonProperty("4. Interval")]
    public string Interval { get; set; }

    [JsonProperty("5. Output Size")]
    public string OutputSize { get; set; }

    [JsonProperty("6. Time Zone")]
    public string TimeZone { get; set; }
}

public class CandleStick
{

    [JsonProperty("1. open")]
    public string Open { get; set; }

    [JsonProperty("2. high")]
    public string High { get; set; }

    [JsonProperty("3. low")]
    public string Low { get; set; }

    [JsonProperty("4. close")]
    public string Close { get; set; }

    [JsonProperty("5. volume")]
    public string Volume { get; set; }
}


public class Result
{

    [JsonProperty("Meta Data")]
    public MetaData MetaData { get; set; }

    [JsonProperty("Time Series (15min)")]
    public Dictionary<DateTime, CandleStick> TimeSeries15min { get; set; }
}

въведете описание на изображението тук

person Aydin    schedule 30.09.2018