检查JObject中的空/ null JToken

时间:2014-06-05 17:22:33

标签: c# sql json.net

我有以下......

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 ..但似乎没有效果。

5 个答案:

答案 0 :(得分:120)

要检查JObject上是否存在属性,可以使用方括号语法查看结果是否为null。如果属性存在,将始终返回JToken(即使它在JSON中具有值null)。

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

如果您手头有JToken并且想要查看它是否为非空,那么这取决于它的JToken类型以及您如何定义"空& #34 ;.我通常使用这样的扩展方法:

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 :(得分:29)

您可以按以下步骤检查JToken值是否为空

JToken token = jObject["key"];

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

答案 2 :(得分:1)

从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运算符将检查Type,如果其正确,则Value在clients变量内。

答案 3 :(得分:0)

还有一个类型-JTokenType.Undefined。

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

token.Type == JTokenType.Undefined

答案 4 :(得分:0)

尝试类似的方法将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
}