检查JObject中的空/ null JToken

Kyl*_*yle 74 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"]);
}
Run Code Online (Sandbox Code Playgroud)

JTokenToSql 看起来像这样......

public static object JTokenToSql(JToken obj)
{
    if (obj.Any())
        return (object)obj;
    else
        return (object)DBNull.Value;
}
Run Code Online (Sandbox Code Playgroud)

我也试过((JObject)obj).Count..但似乎没有工作.

Bri*_*ers 138

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

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

如果你有一个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);
    }
}
Run Code Online (Sandbox Code Playgroud)


Sam*_*ugi 41

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

JToken token = jObject["key"];

if(token.Type == JTokenType.Null)
{
    // Do your logic
}
Run Code Online (Sandbox Code Playgroud)

  • 正是我正在寻找的,因为空参数返回一个通过典型 == null 比较的空类型。谢谢! (5认同)

ale*_*eha 5

还有一种类型 - JTokenType.Undefined。

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

token.Type == JTokenType.Undefined
Run Code Online (Sandbox Code Playgroud)