我正在尝试从Eurostat服务器读取一些数据。我使用Newtonsoft库反序列化服务器返回的字符串:
Product product = JsonConvert.DeserializeObject<Product>(responseText);
完整的JSON字符串是:
{
"version": "2.0",
"label": "Production from aquaculture excluding hatcheries and nurseries (from 2008 onwards)",
"href": "http://ec.europa.eu/eurostat/wdds/rest/data/v2.1/json/en/fish_aq2a?precision=1&species=SAL&aquaenv=SEA&fishreg=0&fishreg=10&fishreg=27&fishreg=5&fishreg=9&fishreg=37&fishreg=34&fishreg=NSP&fishreg=4&fishreg=1&unit=EUR&unit=EUR_T&unit=TLW&aquameth=CAG",
"source": "Eurostat",
"updated": "2017-10-10",
"status": {
"0": ":",
"3": ":",
"5": ":",
"6": ":",
"7": ":",
"13": ":",
"14": ":",
"15": ":",
"17": ":",
"18": ":",
"19": ":",
"20": ":",
"21": ":",
"22": ":",
"23": ":",
"24": ":",
"27": ":",
"28": ":",
"29": ":",
"30": ":",
"31": ":",
"37": ":",
"38": ":",
"39": ":",
"40": ":",
"45": ":",
"46": ":",
"47": ":",
"48": ":",
"51": ":",
"53": ":",
"54": ":",
"55": ":",
"61": ":",
"62": ":",
"63": ":",
"65": ":",
"66": ":",
"67": ":",
"68": ":",
"69": ":",
"70": ":",
"71": ":",
"72": ":",
"75": ":",
"76": ":",
"77": ":",
"78": ":",
"79": ":",
"85": ":",
"86": ":",
"87": ":",
"88": ":",
"93": ":",
"94": ":",
"95": ":",
"96": ":",
"99": ":",
"101": ":",
"102": ":",
"103": ":",
"109": ":",
"110": ":",
"111": ":",
"113": ":",
"114": ":",
"115": ":",
"116": ":",
"117": ":",
"118": ":",
"119": ":",
"120": ":",
"123": ":",
"124": ":",
"125": ":",
"126": ":",
"127": ":",
"133": ":",
"134": ":",
"135": ":",
"136": ":",
"141": ":",
"142": ":",
"143": ":",
"144": ":",
"147": ":",
"149": ":",
"150": ":",
"151": ":",
"157": ":",
"158": ":",
"159": ":",
"161": ":",
"162": ":",
"163": ":",
"164": ":",
"165": ":",
"166": ":",
"167": ":",
"168": ":",
"171": ":",
"172": ":",
"173": ":",
"174": ":",
"175": ":",
"181": ":",
"182": ":",
"183": ":",
"184": ":",
"189": ":",
"190": ":",
"191": ":",
"192": ":",
"195": ":",
"197": ":",
"198": ":",
"199": ":",
"205": ":",
"206": ":",
"207": ":",
"209": ":",
"210": ":",
"211": ":",
"212": ":",
"213": ":",
"214": ":",
"215": ":",
"216": ":",
"219": ":",
"220": ":",
"221": ":",
"222": ":",
"223": ":",
"229": ":",
"230": ":",
"231": ":",
"232": ":",
"237": ":",
"238": ":",
"239": ":",
"240": ":",
"243": ":",
"245": ":",
"246": ":",
"247": ":",
"253": ":",
"254": ":",
"255": ":",
"257": ":",
"258": ":",
"259": ":",
"260": ":",
"261": ":",
"262": ":",
"263": ":",
"264": ":",
"267": ":",
"268": ":",
"269": ":",
"270": ":",
"271": ":",
"277": ":",
"278": ":",
"279": ":",
"280": ":",
"285": ":",
"286": ":",
"287": ":",
"288": ":",
"291": ":",
"293": ":",
"294": ":",
"295": ":",
"301": ":",
"302": ":",
"303": ":",
"305": ":",
"306": ":",
"307": ":",
"308": ":",
"309": ":",
"310": ":",
"311": ":",
"312": ":",
"315": ":",
"316": ":",
"317": ":",
"318": ":",
"319": ":",
"325": ":",
"326": ":",
"327": ":",
"328": ":",
"333": ":",
"334": ":",
"335": ":",
"336": ":",
"339": ":",
"341": ":",
"342": ":",
"343": ":",
"349": ":",
"350": ":",
"351": ":",
"353": ":",
"354": ":",
"355": ":",
"356": ":",
"357": ":",
"358": ":",
"359": ":",
"360": ":",
"363": ":",
"364": ":",
"365": ":",
"366": ":",
"367": ":",
"373": ":",
"374": ":",
"375": ":",
"376": ":",
"381": ":",
"382": ":",
"383": ":",
"384": ":",
"387": ":",
"389": ":",
"390": ":",
"391": ":",
"397": ":",
"398": ":",
"399": ":",
"401": ":",
"402": ":",
"403": ":",
"404": ":",
"405": ":",
"406": ":",
"407": ":",
"408": ":",
"411": ":",
"412": ":",
"413": ":",
"414": ":",
"415": ":",
"421": ":",
"422": ":",
"423": ":",
"424": ":",
"429": ":",
"430": ":",
"431": ":"
},
"extension": {
"datasetId": "fish_aq2a",
"lang": "EN",
"description": null,
"subTitle": null,
"status": {
"label": {
":": "not available"
}
}
},
"class": "dataset",
"value": {
"1": 3243,
"2": 356479,
"4": 14938,
"8": 6007500,
"9": 529723936.38,
"10": 585804684.37,
"11": 677939444.53,
"12": 641218586.15,
"16": 6007500,
"25": 65367944,
"26": 70585535,
"32": 1851387298,
"33": 2311910972,
"34": 3562084862,
"35": 3454753657,
"36": 3739702550,
"41": 464352749,
"42": 514862671,
"43": 677939445,
"44": 641179927,
"49": 1989,
"50": 4501,
"52": 3734,
"56": 4500,
"57": 3376.93,
"58": 3441.86,
"59": 4286.31,
"60": 3946.37,
"64": 4500,
"73": 5354,
"74": 4499,
"80": 2510,
"81": 2679,
"82": 3791,
"83": 3241,
"84": 3035,
"89": 3210,
"90": 3334,
"91": 4286,
"92": 3946,
"97": 2,
"98": 79,
"100": 4,
"104": 1335,
"105": 156865.63,
"106": 170200,
"107": 158164,
"108": 162483,
"112": 1335,
"121": 12210,
"122": 15691,
"128": 737694,
"129": 862908,
"130": 939575,
"131": 1065975,
"132": 1232095,
"137": 144654,
"138": 154430,
"139": 158164,
"140": 162479,
"145": 3243,
"146": 356479,
"148": 14938,
"152": 6007500,
"153": 529723936.38,
"154": 585804684.37,
"155": 677939444.53,
"156": 641218586.15,
"160": 6007500,
"169": 65367944,
"170": 70585535,
"176": 1851387298,
"177": 2311910972,
"178": 3562084862,
"179": 3454753657,
"180": 3739702550,
"185": 464352749,
"186": 514862671,
"187": 677939445,
"188": 641179927,
"193": 1989,
"194": 4501,
"196": 3734,
"200": 4500,
"201": 3376.93,
"202": 3441.86,
"203": 4286.31,
"204": 3946.37,
"208": 4500,
"217": 5354,
"218": 4499,
"224": 2510,
"225": 2679,
"226": 3791,
"227": 3241,
"228": 3035,
"233": 3210,
"234": 3334,
"235": 4286,
"236": 3946,
"241": 2,
"242": 79,
"244": 4,
"248": 1335,
"249": 156865.63,
"250": 170200,
"251": 158164,
"252": 162483,
"256": 1335,
"265": 12210,
"266": 15691,
"272": 737694,
"273": 862908,
"274": 939575,
"275": 1065975,
"276": 1232095,
"281": 144654,
"282": 154430,
"283": 158164,
"284": 162479,
"289": 3243,
"290": 356479,
"292": 14938,
"296": 6007500,
"297": 529723936.38,
"298": 585804684.37,
"299": 677939444.53,
"300": 641218586.15,
"304": 6007500,
"313": 65367944,
"314": 70585535,
"320": 1851387298,
"321": 2311910972,
"322": 3562084862,
"323": 3454753657,
"324": 3739702550,
"329": 464352749,
"330": 514862671,
"331": 677939445,
"332": 641179927,
"337": 1989,
"338": 4501,
"340": 3734,
"344": 4500,
"345": 3376.93,
"346": 3441.86,
"347": 4286.31,
"348": 3946.37,
"352": 4500,
"361": 5354,
"362": 4499,
"368": 2510,
"369": 2679,
"370": 3791,
"371": 3241,
"372": 3035,
"377": 3210,
"378": 3334,
"379": 4286,
"380": 3946,
"385": 2,
"386": 79,
"388": 4,
"392": 1335,
"393": 156865.63,
"394": 170200,
"395": 158164,
"396": 162483,
"400": 1335,
"409": 12210,
"410": 15691,
"416": 737694,
"417": 862908,
"418": 939575,
"419": 1065975,
"420": 1232095,
"425": 144654,
"426": 154430,
"427": 158164,
"428": 162479
},
"dimension": {
"aquameth": {
"label": "aquameth",
"category": {
"index": {
"CAG": 0
},
"label": {
"CAG": "Cages"
}
}
},
"aquaenv": {
"label": "aquaenv",
"category": {
"index": {
"SEA": 0
},
"label": {
"SEA": "Seawater"
}
}
},
"species": {
"label": "species",
"category": {
"index": {
"SAL": 0
},
"label": {
"SAL": "Atlantic salmon - Salmo salar"
}
}
},
"fishreg": {
"label": "fishreg",
"category": {
"index": {
"0": 0,
"10": 1,
"27": 2
},
"label": {
"0": "Total fishing areas",
"10": "Marine areas",
"27": "Atlantic, Northeast"
}
}
},
"unit": {
"label": "unit",
"category": {
"index": {
"EUR": 0,
"EUR_T": 1,
"TLW": 2
},
"label": {
"EUR": "Euro",
"EUR_T": "Euro per tonne",
"TLW": "Tonnes live weight"
}
}
},
"geo": {
"label": "geo",
"category": {
"index": {
"ES": 0,
"EU28": 1,
"FR": 2,
"IE": 3,
"NO": 4,
"UK": 5
},
"label": {
"ES": "Spain",
"EU28": "European Union (28 countries)",
"FR": "France",
"IE": "Ireland",
"NO": "Norway",
"UK": "United Kingdom"
}
}
},
"time": {
"label": "time",
"category": {
"index": {
"2008": 0,
"2009": 1,
"2010": 2,
"2011": 3,
"2012": 4,
"2013": 5,
"2014": 6,
"2015": 7
},
"label": {
"2008": "2008",
"2009": "2009",
"2010": "2010",
"2011": "2011",
"2012": "2012",
"2013": "2013",
"2014": "2014",
"2015": "2015"
}
}
}
},
"id": [
"aquameth",
"aquaenv",
"species",
"fishreg",
"unit",
"geo",
"time"
],
"size": [
1,
1,
1,
3,
3,
6,
8
]
}
在我的产品类(MSVS 2015 C#)中,我有:
public Dictionary<string, dynamic> Extension { get; set; }
一直工作正常,直到我进入&#34;状态&#34;键,给出错误。
我的解决方法是:
MyRow++;
MyCol = 0;
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = nameof(product.Extension) + ":";
foreach (string key in product.Extension.Keys)
{
MyRow++;
MyCol = 0;
dynamic myvalue = key;
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = myvalue;
if (key == "status")
break;
MyCol = 1;
myvalue = product.Extension[key];
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = myvalue;
}
注意:MyRow&amp; MyCol变量用于输出到电子表格加载项,与问题无关。我已经检查了网上的一些例子,主要是关于stackoverflow,但无法解决。
答案 0 :(得分:1)
由于":"
JSON键,使用dynamic
和鸭子输入会导致一些问题。
考虑为该属性创建强类型,如下所示
public class Extension {
public string datasetId { get; set; }
public string lang { get; set; }
public string description { get; set; }
public string subTitle { get; set; }
public ExtensionStatus status { get; set; }
}
public class ExtensionStatus {
public Dictionary<string, string> label { get; set; }
}
并且
public Extension extension { get; set; }
在您的Product
班级
对于dimension
属性,您需要做的是在嵌套对象中查找公共模式。
基于提供的JSON Dimension
将解析为以下
public class Dimension {
public DimensionDetail aquameth { get; set; }
public DimensionDetail aquaenv { get; set; }
public DimensionDetail species { get; set; }
public DimensionDetail fishreg { get; set; }
public DimensionDetail unit { get; set; }
public DimensionDetail geo { get; set; }
public DimensionDetail time { get; set; }
}
public class DimensionDetail {
public string label { get; set; }
public Category category { get; set; }
}
public class Category {
public Dictionary<string, int> index { get; set; }
public Dictionary<string, string> label { get; set; }
}
将属性设置为Product
public Dimension dimension { get; set; }
在反序列化字符串后,您可以像
一样访问它var product = JsonConvert.DeserializeObject<Product>(responseText);
var value = product.extension.status.label[":"]; //value should equal "not available"
答案 1 :(得分:1)
阅读json&#34;维度的方法&#34;组件进入C#类是为了创建以下内容:
public class Dimension
{
public DimensionAquameth aquameth { get; set; }
}
public class DimensionAquameth
{
public string label { get; set; }
public DimensionCategory category { get; set; }
}
public class DimensionCategory
{
public Dictionary<string, string> index { get; set; }
public Dictionary<string, string> label { get; set; }
}
然后添加:
public Dimension dimension { get; set; }
到产品类。
在解析反序列化json的代码中:
// Dimension field
MyRow++;
MyCol = 0;
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = nameof(product.dimension) + ":";
// aquameth
MyRow++;
MyCol = 0;
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = nameof(product.dimension.aquameth) + ":";
// label
MyRow++;
MyCol = 0;
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = nameof(product.dimension.aquameth.label) + ":";
MyCol = 1;
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = product.dimension.aquameth.label;
// category
MyRow++;
MyCol = 0;
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = nameof(product.dimension.aquameth.category) + ":";
// category index
MyRow++;
MyCol = 0;
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = nameof(product.dimension.aquameth.category.index) + ":";
// CAG
foreach (string key in product.dimension.aquameth.category.index.Keys)
{
MyRow++;
MyCol = 0;
dynamic myvalue = key;
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = myvalue + ":";
MyCol = 1;
myvalue = product.dimension.aquameth.category.index[key];
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = myvalue;
}
MyRow++;
MyCol = 0;
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = nameof(product.dimension.aquameth.category.label) + ":";
// CAG
foreach (string key in product.dimension.aquameth.category.label.Keys)
{
MyRow++;
MyCol = 0;
dynamic myvalue = key;
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = myvalue + ":";
MyCol = 1;
myvalue = product.dimension.aquameth.category.label[key];
QueryOutputWS.ActiveWorksheet.Cells[MyRow, MyCol].Value = myvalue;
}
请注意,QueryOutputWS参考以及MyRow,MyCol特定于将结果解码字段输出到SpreadsheetGear工作表 - 您可以使用任何其他输出方法,包括控制台输出等。