在JObject中检查空或null的JToken

123

我有以下的...

JArray clients = (JArray)clientsParsed["objects"];

foreach (JObject item in clients.Children())
{
    // etc.. SQL params stuff...
    command.Parameters["@MyParameter"].Value = JTokenToSql(item["thisParameter"]);
}

JTokenToSql 的实现如下...

public static object JTokenToSql(JToken obj)
{
    if (obj.Any())
        return (object)obj;
    else
        return (object)DBNull.Value;
}

我已经尝试过((JObject)obj).Count,但似乎没起作用。

6个回答

238

要检查 JObject 是否存在某个属性,可以使用方括号语法并查看结果是否为 null。如果该属性存在,则始终会返回一个 JToken(即使在 JSON 中它的值为 null)。

JToken token = jObject["param"];
if (token != null)
{
    // the "param" property exists
}

如果您手头有一个 JToken,并且想要查看它是否为空,那取决于 JToken 的类型以及您如何定义“空”。我通常使用类似以下的扩展方法:

public static class JsonExtensions
{
    public static bool IsNullOrEmpty(this JToken token)
    {
        return (token == null) ||
               (token.Type == JTokenType.Array && !token.HasValues) ||
               (token.Type == JTokenType.Object && !token.HasValues) ||
               (token.Type == JTokenType.String && token.ToString() == String.Empty) ||
               (token.Type == JTokenType.Null);
    }
}

1
我会将它作为扩展方法,类似这样:public static bool IsNullOrEmpty(this JToken token) { ... }以便使用:JToken token = jObject["param"]; bool empty = token.IsNullOrEmpty() - Dmitry Pavlov
1
你能不能不要对 JToken 进行 ToString 操作,而是先检查它是否为 null 或空字符串?(当然,在确认 JToken 不为 null 之后) - Paul C
1
@CodeBlend 对于对象或数组,这种方法不起作用 - 当它们为空时,它们的序列化版本分别为 {}[] - Brian Rogers
1
我会添加属性检查: return (token == null) || (token.Type == JTokenType.Array && !token.HasValues) || (token.Type == JTokenType.Object && !token.HasValues) || (token.Type == JTokenType.String && token.ToString() == String.Empty) || (token.Type == JTokenType.Null) || (token.Type == JTokenType.Property && ((JProperty)token).Value.ToString() == string.Empty); - jcmontx
如果应该使用".Property"符号,则JToken token = jObject["param"];可以写成JToken token = jObject.Property("param")?.Value; - undefined

85

您可以按照以下步骤检查JToken值是否为null:

JToken token = jObject["key"];

if(token.Type == JTokenType.Null)
{
    // Do your logic
}

5
正是我所需要的,由于空参数返回一个空类型,可以通过典型的“==null”比较来传递。谢谢! - Tim Tyler

9

还有一种类型 - JTokenType.Undefined。

在 @Brian Rogers 的答案中必须包含此检查。

token.Type == JTokenType.Undefined

如果必须包含在Brian的答案中,则建议您在该答案的评论中发布它。 - Nande

4

现在在C# 6+中,可以使用null-conditional访问运算符 ?[] 直接访问。

    foreach (JObject item in clients.Children())
    {
        // value will be null if access fails
        var value = (string)item?["thisParameter"]?["anotherNode"]?["oneMoreNestedNode"];
    } 

3
截至C# 7,您也可以使用以下内容:
if (clientsParsed["objects"] is JArray clients) 
{
    foreach (JObject item in clients.Children())
    {
        if (item["thisParameter"] as JToken itemToken) 
        {
            command.Parameters["@MyParameter"].Value = JTokenToSql(itemToken);
        }
    }
}

is 运算符检查类型,如果正确,客户端变量中的值就在其内部。

1
尝试使用以下方法将JToken转换为JArray:

尝试使用以下方法将JToken转换为JArray:

static public JArray convertToJArray(JToken obj)
{
    // if ((obj).Type == JTokenType.Null) --> You can check if it's null here

    if ((obj).Type == JTokenType.Array)
        return (JArray)(obj);
    else
        return new JArray(); // this will return an empty JArray
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接