我有一个多态的 json 字符串。这是它的样子:
{
"?xml" : {
"@version" : "1.0",
"@encoding" : "UTF-8"
},
"DataFeed" : {
"@FeedName" : "complianceCompany",
"Companies" : {
"@timeStamp" : "2016-07-06T10:16:51.00",
"Company" : [{
"@id" : "1",
"Ticker" : "MSFT-NSDQ",
"Name" : "Microsoft",
"Disclosure" : {
"@Code" : "25",
"@Description" : "25: PERSON FINANCIAL INTEREST"
}
}, {
"@id" : "3",
"Ticker" : "AAPL-NSDQ",
"Name" : "Apple",
"Disclosure" : [{
"@Code" : "3",
"@Description" : "03: RECEIVED COMP FOR NON-IB SVS"
}, {
"@Code" : "6C",
"@Description" : "06C: CLIENT NON SEC REL SVS"
}, {
"@Code" : "39",
"@Description" : "39: MARKET MAKER"
}
]
}
]
}
}
}
有人曾经帮助我使用以下扩展类:
public static class JsonExtensions
{
public static IEnumerable<JObject> ObjectsOrSelf(this JToken root)
{
if (root is JObject)
yield return (JObject)root;
else if (root is JContainer)
foreach (var item in ((JContainer)root).Children())
foreach (var child in item.ObjectsOrSelf())
yield return child;
else
yield break;
}
}
基于此,这是我的查询:
JObject feed = JObject.Parse(jsonText);
var discInfo = from issuer in feed.SelectTokens("DataFeed.Companies.Company").SelectMany(i => i.ObjectsOrSelf())
let discs = issuer.SelectTokens("Disclosure").SelectMany(s => s.ObjectsOrSelf())
select new
{
Id = (int)issuer["@id"],
Ticker = (string)issuer["Ticker"],
CompName = (string)issuer["Name"],
DiscCode = (string)discs["@Code"],
};
当我尝试查询时,我收到以下错误:
Cannot apply indexing with [] to an expression of type 'IEnumerable<JObject>'
我正在尝试将所有光盘放在逗号分隔的字段中,用于每个股票代码。最终结果应如下所示:
我怎样才能得到最终结果?