Перевірка порожнього або нульового значення JToken у JObject


90

У мене є таке ...

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також пробував .. Але, схоже, це не працює.

Відповіді:


175

Щоб перевірити, чи існує властивість на a JObject, ви можете скористатися синтаксисом квадратних дужок і побачити, чи є результат нульовим чи ні. Якщо властивість існує, а JTokenзавжди буде повернуто (навіть якщо воно має значення nullв JSON).

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);
    }
}

1
Я б зробив його методом розширення на зразок: public static bool IsNullOrEmpty (цей маркер JToken) {...} для використання як JToken token = jObject ["param"]; bool empty = token.IsNullOrEmpty ()
Дмитро Павлов

1
Могли б ви не та перевірити ? (Перевіривши, звичайно, не нуль)ToSrtingJTokenIsNullOrWhiteSpaceJToken
Купс

1
@CodeBlend Це не працюватиме для об'єкта чи масиву - серіалізовані версії тих, що є порожніми, {}і []відповідно.
Брайан Роджерс

1
Я додав би перевірку властивостей: 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) маркер) .Value.ToString () == string.Empty);
jcmontx

59

Ви можете виконати наступні дії, щоб перевірити, чи є значення JToken нульовим

JToken token = jObject["key"];

if(token.Type == JTokenType.Null)
{
    // Do your logic
}

3
Саме те, що я шукав, через порожні параметри, що повертають нульовий тип, який проходить типове порівняння == null. Дякую!
Тім Тайлер

4

Існує також тип - JTokenType.Undefined.

Ця перевірка повинна бути включена у відповідь @Brian Rogers.

token.Type == JTokenType.Undefined

1

Станом на 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 перевіряє тип і, якщо він виправляє значення, знаходиться всередині змінної клієнтів.


0

Спробуйте щось подібне, щоб перетворити 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
}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.