[c#] JObject에서 비어 있거나 null JToken 확인

다음이 있습니다 …

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해봤는데 ..하지만 작동하지 않는 것 같습니다.



답변

에 속성이 있는지 확인하려면 JObject대괄호 구문을 사용하고 결과가 null인지 여부를 확인할 수 있습니다. 속성이 존재하면 a JToken가 항상 반환됩니다 ( nullJSON에 값이 있더라도 ).

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


답변

JToken 값이 null인지 확인하려면 다음과 같이 진행할 수 있습니다.

JToken token = jObject["key"];

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


답변

유형-JTokenType.Undefined도 있습니다.

이 수표는 @Brian Rogers 답변에 포함되어야합니다.

token.Type == JTokenType.Undefined


답변

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 연산자는 유형을 확인하고 올바른 경우 값이 클라이언트 변수 내에 있습니다.


답변

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
}


답변