JObjectで空またはnullのJTokenをチェックする


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ましたが..でも動作していないようです。

回答:


176

プロパティがに存在するかどうかを確認するにはJObject、角括弧構文を使用して、結果がnullかどうかを確認します。プロパティが存在する場合、JTokennullJSONに値がある場合でも)常にaが返されます。

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
次のような拡張メソッドにします。publicstaticboolIsNullOrEmpty(this JToken token){...} JToken token = jObject ["param"];のように使用します。bool empty = token.IsNullOrEmpty()
Dmitry Pavlov

1
あなたはできませんでしたし、チェック?(確認後のコースのnullではない)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)token).Value.ToString()== string.Empty);
jcmontx

59

次の手順に従って、JToken値がnullかどうかを確認できます。

JToken token = jObject["key"];

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

3
空のパラメータが典型的な== null比較に合格するnull型を返すため、まさに私が探していたものです。ありがとう!
ティムタイラー

4

タイプもあります-JTokenType.Undefined。

このチェックは、@ BrianRogersの回答に含める必要があります。

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
}
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.