Comprobación de JToken vacío o nulo en un JObject

90

Tengo lo siguiente ...

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

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

JTokenToSql Se ve como esto...

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

También lo he intentado ((JObject)obj).Count... Pero parece que no funciona.

Kyle
fuente

Respuestas:

176

Para verificar si una propiedad existe en a JObject, puede usar la sintaxis de corchetes y ver si el resultado es nulo o no. Si la propiedad existe, JTokensiempre se devolverá un (incluso si tiene el valor nullen el JSON).

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

Si tiene un JTokenen la mano y quiere ver si no está vacío, bueno, eso depende de qué tipo JTokensea ​​y cómo defina "vacío". Normalmente uso un método de extensión 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
fuente
1
Lo haría un método de extensión como: public static bool IsNullOrEmpty (este token JToken) {...} para usar como JToken token = jObject ["param"]; bool vacío = token.IsNullOrEmpty ()
Dmitry Pavlov
1
¿No podría ToSrtingel JTokeny comprobar IsNullOrWhiteSpace? (Después de comprobar JTokenque no es nulo, por supuesto)
Coops
1
@CodeBlend Eso no funcionará para un objeto o una matriz; las versiones serializadas de aquellos cuando están vacías son {}y []respectivamente.
Brian Rogers
1
Agregaría Comprobación de propiedad: 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
59

Puede proceder de la siguiente manera para verificar si un valor JToken es nulo

JToken token = jObject["key"];

if(token.Type == JTokenType.Null)
{
    // Do your logic
}
Sam Ngugi
fuente
3
Exactamente lo que estaba buscando, debido a los parámetros vacíos que devuelven un tipo nulo que pasa una comparación típica == nula. ¡Gracias!
Tim Tyler
4

También hay un tipo: JTokenType.Undefined.

Esta verificación debe incluirse en la respuesta de @Brian Rogers.

token.Type == JTokenType.Undefined
aleha
fuente
1

A partir de C # 7, también puede usar esto:

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

El operador is comprueba el tipo y, si lo corrige, el valor está dentro de la variable clientes.

Sebastián
fuente
0

Pruebe algo como esto para convertir JToken a 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
}
vive el amor
fuente