Reputation: 9527
I need to get a JSON property dynamically at run time. The JSON looks like this:
{
"timestamp": 1369828868,
"base": "USD",
"rates": {
"AED": 3.673416,
"AFN": 54.135233,
"ALL": 108.828249,
"AMD": 419.878748,
"ANG": 1.788475,
"AOA": 96.154668,
"XDR": 0.66935,
"XOF": 507.521247,
"XPF": 92.277412,
"YER": 214.913206,
"ZAR": 9.769538,
"ZMK": 5227.108333,
"ZMW": 5.316935,
"ZWL": 322.322775
}
}
I need to get a currency from the "Rates" array above. I need some help figuring out how to query the JSON structure. I'm using Newtonsoft.
What I wan't to avoid doing is hard coding a switch statement in C#, so I do NOT want to do this:
var json = JsonConvert.DeserializeObject(jsonString) as dynamic;
switch (currencyPair.QuoteCurrencyCode)
{
case "EUR":
exchangeRate = json.rates.EUR;
break;
case "CNY":
exchangeRate = json.rates.CNY;
break;
case "NZD":
exchangeRate = json.rates.NZD;
break;
case "USD":
exchangeRate = json.rates.USD;
break;
case "GBP":
exchangeRate = json.rates.GBP;
break;
case "HKD":
exchangeRate = json.rates.HKD;
break;
case "JPY":
exchangeRate = json.rates.JPY;
break;
case "CAD":
exchangeRate = json.rates.CAD;
break;
default:
throw new Exception("Unsupported to currency: " + currencyPair.QuoteCurrencyCode);
}
Upvotes: 1
Views: 2637
Reputation: 2064
You can use Json.Net to do this: Example:
string json = @"{
""timestamp"": 1369828868,
""base"": ""USD"",
""rates"": {
""AED"": 3.673416,
""AFN"": 54.135233,
""ALL"": 108.828249,
""AMD"": 419.878748,
""ANG"": 1.788475,
""AOA"": 96.154668,
""XDR"": 0.66935,
""XOF"": 507.521247,
""XPF"": 92.277412,
""YER"": 214.913206,
""ZAR"": 9.769538,
""ZMK"": 5227.108333,
""ZMW"": 5.316935,
""ZWL"": 322.322775
}
}";
dynamic data = Newtonsoft.Json.JsonConvert.DeserializeObject(json);
if (data.@base == "USD")
{
}
// Get the rates
foreach (var rate in data.rates) { };
Upvotes: 0
Reputation: 35353
You can create a dictionary, using Json.Net
var jObj = JObject.Parse(json);
var rates = jObj["rates"].Children().Cast<JProperty>()
.ToDictionary(p => p.Name, p => (double)p.Value);
//A single statement instead of switch
var exchangeRate = rates[currencyPair.QuoteCurrencyCode];
Upvotes: 2