读取 JSON 文件时键值对值为 0

JJu*_*ess 3 c# json.net restsharp

我正在尝试在 C# 中学习 JSON 和 webrequests,但遇到了这个问题:

键值对的值始终为 0。

JSON(来自这个 api):

  "rates": {
    "2020-08-03": { "JPY": 124.51 },
    "2020-08-25": { "JPY": 125.67 },
    "2019-11-20": { "JPY": 119.96 },
    "2020-04-08": { "JPY": 118.36 }
  },
  "start_at": "2019-10-28",
  "base": "EUR",
  "end_at": "2020-10-28"
}
Run Code Online (Sandbox Code Playgroud)

转换.cs

public partial class ConversionRatesLastYear
{
    [JsonProperty("rates")]
    public Dictionary<string, Rate> Rates { get; set; }

    [JsonProperty("start_at")]
    public DateTimeOffset StartAt { get; set; }

    [JsonProperty("base")]
    public string Base { get; set; }

    [JsonProperty("end_at")]
    public DateTimeOffset EndAt { get; set; }
}

public partial class Rate
{
    public double Valuta { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

我的方法

public void SelectedValuta(string valuta)
    {
        IRestClient restClient = new RestClient();
        DateTime dtLastYear = DateTime.Today.AddYears(-1);
        DateTime dtToday = DateTime.Today;

        string lastYear = dtLastYear.ToString("yyyy-MM-dd");
        string today = dtToday.ToString("yyyy-MM-dd");

        Console.WriteLine(lastYear + " " + today);
        IRestRequest request = new RestRequest(url + "history?start_at=" + lastYear + "&end_at=" + today + "&symbols="+valuta, DataFormat.Json);

        var response = restClient.Get<List<ConversionRatesLastYear>>(request);

        foreach (var kvp in response.Data[0].Rates)
        {
            //gives Value = EuroDollarConverterRealtime.Rate
            Console.WriteLine("Key = {0}, Value = {1}", kvp.Key, kvp.Value);

            //gives Value = 0
            Console.WriteLine("Key = {0}, Value = {1}", kvp.Key, (double)kvp.Value.Valuta);
        }
}
Run Code Online (Sandbox Code Playgroud)

当我这样做时,我可以看到 JSON 中的全部内容:

Console.WriteLinke(response.Content)
Run Code Online (Sandbox Code Playgroud)

所以问题不在于获取信息。我可以在另一种方法中毫无问题地使用“start_at”、“base”、“end_at”,但不能使用“rates”。当我做利率时,我只能得到日期,并且取决于我是否使用 kvp.Value 我得到 EuroDollarConverterRealtime.Rate 或者当我做 kvp.Value.Valuta 我得到 0。

我的目标是从 JPY 获得每个日期的双倍价值。如果我只能使用日期和日元的双倍值,我就可以了。注意:JPY 是一个例子,这可以是除 EUR 之外的所有货币。

抱歉,如果我无法按名称获取每个元素,我仍在学习。

Jon*_*eet 5

再看一下ratesJSON:

"rates": {
  "2020-08-03": { "JPY": 124.51 },
  "2020-08-25": { "JPY": 125.67 },
  "2019-11-20": { "JPY": 119.96 },
  "2020-04-08": { "JPY": 118.36 }
}
Run Code Online (Sandbox Code Playgroud)

你已经声明了 as Dictionary<string, Rate>,这很好 - 但这意味着你期待这样的事情:

{ "JPY": 124.51 }
Run Code Online (Sandbox Code Playgroud)

... 被反序列化为Rate. 您有一个Valuta没有JsonProperty属性的属性 ,那么您希望 Json.NET 对 JSON 中的“JPY”属性做什么?

如果您只想获得 JPY 作为密钥,您可以指定 on Rate

public partial class Rate
{
    [JsonProperty("JPY")]
    public double Valuta { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

...但我怀疑仅声明Rates为 a更有意义Dictionary<string, Dictionary<string, double>>(并Rate完全删除您的课程)。