如何將 JSON 反序列化為 C# 物件?
這是我的 JSON:
{
"date": "2020-07-02 10:39:00 00",
"base": "USD",
"rates": {
"FJD": 2.1692,
"MXN": 22.602,
[...]
}
}
根模型
public class BaseCurrencyModel
{
public DateTime Date { get; set; }
public string Base { get; set; }
public IEnumerable<RatesModel> Rates { get; set; }
}
陣列值的物件:
public class RatesModel
{
public string currencyCode { get; set; }
public string rate { get; set; }
}
當我使用
public Dictionary<string, string> Rates
進入根模型一切正常。如果我使用
IEnumerable<RatesModel> Rates
我得到錯誤
無法將當前 JSON 物件反序列化為型別“System.Collections.Generic.IEnumerable`1[CurrencyConverter.Models.RatesModel]”,因為該型別需要 JSON 陣列(例如 [1,2,3])才能正確反序列化。
要修復此錯誤,請將 JSON 更改為 JSON 陣列
uj5u.com熱心網友回復:
json rate 不是陣列,它是字典
public class BaseCurrencyModel
{
public DateTime Date { get; set; }
public string Base { get; set; }
public Dictionary<string,double> Rates { get; set; }
}
或者您可以將其轉換為串列
var ratesParsed= JObject.Parse(json);
BaseCurrencyModel rates = new BaseCurrencyModel
{
Date = ratesParsed["date"].ToObject<DateTime>(),
Base = (string)ratesParsed["base"],
Rates = ((JObject)ratesParsed["rates"]).Properties().Select(x =>
new RatesModel { currencyCode = x.Name,
rate = Convert.ToDouble(x.Value) }
).ToList()
};
班級
public class BaseCurrencyModel
{
public DateTime Date { get; set; }
public string Base { get; set; }
public List<Rate> Rates { get; set; }
}
輸出(以 json 格式)
{
"Date": "2020-07-02T08:09:00-02:30",
"Base": "USD",
"Rates": [
{
"currencyCode": "FJD",
"rate": 2.1692
},
{
"currencyCode": "MXN",
"rate": 22.602
}
]
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/412329.html
標籤:
上一篇:如何匹配多維json中的兩個值
