0

我得到了这样的json对象-

在此处输入图像描述

有时像这样-

在此处输入图像描述

所以对象的顺序是不固定的。在上面的示例中,“CreatedOn”字段需要存储在 DB 中。

我正在使用以下代码将其转换为 expandoobject -

    JObject jsonObject = JObject.Parse(json);

    // eval into an expando
    dynamic dynObject = ConvertJTokenToObject(jsonObject);

在这里 ConvertJTokenToObject -

public object ConvertJTokenToObject(JToken token)
        {
            if (token is JValue)
            {
                return ((JValue)token).Value;
            }

            if (token is JObject)
            {
                ExpandoObject expando = new ExpandoObject();
                (from childToken in ((JToken)token) where childToken is JProperty select childToken as JProperty).ToList().ForEach(property =>
                {
                    ((IDictionary<string, object>)expando).Add(property.Name, ConvertJTokenToObject(property.Value));
                });

                return expando;
            }

            if (token is JArray)
            {
                object[] array = new object[((JArray)token).Count];
                int index = 0;
                foreach (JToken arrayItem in ((JArray)token))
                {
                    array[index] = ConvertJTokenToObject(arrayItem);
                    index++;
                }
                return array;
            }
            throw new ArgumentException(string.Format("Unknown token type '{0}'", token.GetType()), "token");
        }

现在,问题是我不知道哪个“维度”元素将具有“CreatedOn”字段。

这适用于第一种情况 -

dynObject.context.custom.dimensions[0].CreatedOn

但在另一种情况下会中断,因为它应该是 -

dynObject.context.custom.dimensions[1].CreatedOn

如何按“CreatedOn”、“Status”等字段名称搜索 expandoobject。

4

2 回答 2

0

由于 ExpandoObject 实现了 IDictionary,所以您不能只执行以下操作:

if (dynObject.context.custom.dimensions[1] as IDictionary<string,object>).ContainsKey("CreatedOn") {
//Your logic here... 
}
于 2016-07-21T10:19:40.693 回答
0

你将不得不展平尺寸,我认为你的问题是没有通过名称在expando中找到属性,你可以通过点符号展平expando结构来做到这一点......如果你需要知道的话,我可以发布somat。但是你的主要问题源于维度是一个dynamic[],所以你需要得到像这样的维度var dimensions = dynObject.Context.Custom.dimensions,然后像var flattened = FlattenDimensions(dimensions)这样将它们展平会给你一个像这样的字典

在此处输入图像描述

展平方法

private static Dictionary<string, object> FlattenDimensions(dynamic[] dimensions)
    {
        var flattened = new Dictionary<string, object>();
        foreach (var dimension in dimensions)
        {
            var dict = (IDictionary<string, object>)dimension;
            foreach (var item in dict)
            {
                flattened.Add(item.Key, item.Value);
            }
        }
        return flattened;
    }

您可以调整上述方法以更好地满足您的需要,但这是一个想法 而且由于您现在有一个扁平字典,您可以搜索 CreatedOn 或任何其他属性

--希望这是有道理的

于 2016-07-21T11:52:30.313 回答