Verificando se há JToken vazio ou nulo em um JObject

93

Eu tenho o seguinte ...

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

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

JTokenToSql se parece com isso...

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

Eu tentei ((JObject)obj).Counttambém .. Mas não parece estar funcionando.

Kyle
fonte

Respostas:

182

Para verificar se uma propriedade existe em a JObject, você pode usar a sintaxe de colchetes e ver se o resultado é nulo ou não. Se a propriedade existir, a JTokensempre será retornado (mesmo que tenha o valor nullno JSON).

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

Se você tem um JTokenem mãos e quer ver se não está vazio, bem, isso depende de que tipo JTokené e como você define "vazio". Eu costumo usar um método de extensão como este:

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);
    }
}
Brian Rogers
fonte
1
Gostaria de torná-lo um método de extensão como: public static bool IsNullOrEmpty (este token JToken) {...} para usar como token JToken = jObject ["param"]; bool empty = token.IsNullOrEmpty ()
Dmitry Pavlov
1
Você poderia não ToSrtingo JTokene verificar IsNullOrWhiteSpace? (Depois de verificar JTokense não é nulo, é claro)
Coops
1
@CodeBlend Isso não funcionará para um objeto ou array - as versões serializadas daqueles quando vazios são {}e []respectivamente.
Brian Rogers
1
Eu adicionaria a verificação de propriedade: 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
64

Você pode proceder da seguinte forma para verificar se um valor JToken é nulo

JToken token = jObject["key"];

if(token.Type == JTokenType.Null)
{
    // Do your logic
}
Sam Ngugi
fonte
4
Exatamente o que eu estava procurando, devido aos parâmetros vazios retornando um tipo nulo que passa por uma comparação típica == nulo. Obrigado!
Tim Tyler
5

Também existe um tipo - JTokenType.Undefined.

Este cheque deve ser incluído na resposta de @Brian Rogers.

token.Type == JTokenType.Undefined
aleha
fonte
1

A partir do C # 7, você também pode usar isto:

if (clientsParsed["objects"] is JArray clients) 
{
    foreach (JObject item in clients.Children())
    {
        if (item["thisParameter"] as JToken itemToken) 
        {
            command.Parameters["@MyParameter"].Value = JTokenToSql(itemToken);
        }
    }
}

O operador is verifica o tipo e se está correto o valor está dentro da variável do cliente.

Sebastian
fonte
0

Tente algo assim para converter JToken em 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
}
amor ao vivo
fonte