0

我有一个多态的 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>'

我正在尝试将所有光盘放在逗号分隔的字段中,用于每个股票代码。最终结果应如下所示:

最终结果

我怎样才能得到最终结果?

4

1 回答 1

1

当你这样做...

DiscCode = (string)discs["@Code"]

...您正在尝试访问"@Code"公开的属性JObject。但是discs是类型IEnumerable<JObject>!您必须收集所有"@Code"sdiscs并将它们连接起来。

LINQAggregate()可以做到这一点,但我认为它总是看起来更易读string.Join()

DiscCode = string.Join(", ", discs.Select(d => (string)d["@Code"]))
于 2016-07-06T16:04:04.407 回答