Sprawdzanie pustego lub zerowego JToken w JObject

90

Mam następujące ...

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

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

JTokenToSql wygląda tak...

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

Próbowałem ((JObject)obj).Countteż… Ale nie wydaje się działać.

Kyle
źródło

Odpowiedzi:

177

Aby sprawdzić, czy właściwość istnieje na a JObject, możesz użyć składni nawiasu kwadratowego i sprawdzić, czy wynik ma wartość null, czy nie. Jeśli właściwość istnieje, JTokenzawsze zostanie zwrócona wartość a (nawet jeśli ma wartość nullw formacie JSON).

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

Jeśli masz JTokenw ręku i chcesz zobaczyć, czy nie jest pusty, cóż, zależy to od tego, jakiego typu JTokenjest i jak zdefiniujesz „pusty”. Zwykle używam takiej metody rozszerzenia:

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
źródło
1
Zrobiłbym to metodą rozszerzającą, taką jak: public static bool IsNullOrEmpty (ten token JToken) {...} do użycia jak token JToken = jObject ["param"]; bool empty = token.IsNullOrEmpty ()
Dmitry Pavlov
1
Mogłaś nie i sprawdzić ? ( Oczywiście po sprawdzeniu, że nie jest zerowe)ToSrtingJTokenIsNullOrWhiteSpaceJToken
Coops
1
@CodeBlend który będzie nie działać dla obiektu lub tablicy - szeregowej wersje tych, gdy są puste {}i []odpowiednio.
Brian Rogers
1
Dodałbym sprawdzanie właściwości: 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 && (token (JProperty)) .Value.ToString () == string.Empty);
jcmontx
59

Aby sprawdzić, czy wartość JToken jest zerowa, możesz wykonać następujące czynności

JToken token = jObject["key"];

if(token.Type == JTokenType.Null)
{
    // Do your logic
}
Sam Ngugi
źródło
3
Dokładnie to, czego szukałem, ze względu na puste parametry zwracające typ null, który przechodzi typowe porównanie == null. Dzięki!
Tim Tyler,
4

Istnieje również typ - JTokenType.Undefined.

To sprawdzenie musi być zawarte w odpowiedzi @Brian Rogers.

token.Type == JTokenType.Undefined
aleha
źródło
1

Od C # 7 możesz również użyć tego:

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

Operator is sprawdza typ i jeśli go poprawia, wartość znajduje się wewnątrz zmiennej klienta.

Sebastian
źródło
0

Spróbuj czegoś takiego, aby przekonwertować JToken na 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
}
miłość na żywo
źródło