检查 JObject 中的空或 null JToken

Posted

技术标签:

【中文标题】检查 JObject 中的空或 null JToken【英文标题】:Checking for empty or null JToken in a JObject 【发布时间】:2014-07-26 19:30:48 【问题描述】:

我有以下...

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

【问题讨论】:

【参考方案1】:

要检查JObject 上是否存在属性,可以使用方括号语法并查看结果是否为空。如果该属性存在,则将始终返回 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);
    

【讨论】:

我会将其设为扩展方法,例如: public static bool IsNullOrEmpty(this JToken token) ... 使用 JToken token = jObject["param"]; bool empty = token.IsNullOrEmpty() 您不能ToSrting JToken 并检查IsNullOrWhiteSpace 吗? (检查后JToken当然不为空) @CodeBlend 这不适用于对象或数组——空时的序列化版本分别为[] 我会添加属性检查: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);【参考方案2】:

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

JToken token = jObject["key"];

if(token.Type == JTokenType.Null)

    // Do your logic

【讨论】:

正是我正在寻找的,因为空参数返回一个通过典型 == null 比较的空类型。谢谢!【参考方案3】:

还有一个类型——JTokenType.Undefined。

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

token.Type == JTokenType.Undefined

【讨论】:

【参考方案4】:

从 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 运算符检查类型,如果正确,则值在客户端变量内。​​

【讨论】:

【参考方案5】:

尝试这样的方法将 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

【讨论】:

以上是关于检查 JObject 中的空或 null JToken的主要内容,如果未能解决你的问题,请参考以下文章

如何检查 MySQL 中的列是不是为空或 null?

使用 Spotify Apps API 的空或未定义的艺术家图像

检查列表是不是为空或 null 颤动

为啥使用 null 函数而不是 == [] 来检查 Haskell 中的空列表?

检查对象中的值是不是为空或空javascript

检查空或 null List<string>