Проверка пустого или нулевого JToken в JObject

93

У меня есть следующие ...

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.. Но, похоже, не работает.

Кайл
источник

Ответы:

182

Чтобы проверить, существует ли свойство в a JObject, вы можете использовать синтаксис квадратных скобок и посмотреть, является ли результат нулевым или нет. Если свойство существует, JTokenвсегда будет возвращаться a (даже если оно имеет значение 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 = jObject ["param"]; bool empty = token.IsNullOrEmpty ()
Дмитрий Павлов
1
Не могли бы вы ToSrtingто JTokenи проверить IsNullOrWhiteSpace? (После проверки, JTokenконечно, не
ноль
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) token) .Value.ToString () == string.Empty);
jcmontx
64

Вы можете выполнить следующие действия, чтобы проверить, равно ли значение JToken null.

JToken token = jObject["key"];

if(token.Type == JTokenType.Null)
{
    // Do your logic
}
Сэм Нгуги
источник
4
Именно то, что я искал, из-за пустых параметров, возвращающих нулевой тип, который проходит типичное сравнение == null. Благодаря!
Тим Тайлер
5

Еще есть тип - 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
}
живи любя
источник