반응형
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
가 항상 반환됩니다 ( 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);
}
}
JToken 값이 null인지 확인하려면 다음과 같이 진행할 수 있습니다.
JToken token = jObject["key"];
if(token.Type == JTokenType.Null)
{
// Do your logic
}
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 연산자는 유형을 확인하고 올바른 경우 값이 클라이언트 변수 내에 있습니다.
There is also a type - JTokenType.Undefined.
This check must be included in @Brian Rogers answer.
token.Type == JTokenType.Undefined
참고URL : https://stackoverflow.com/questions/24066400/checking-for-empty-null-jtoken-in-a-jobject
반응형
'Programing' 카테고리의 다른 글
AngularJS를 사용하여 새 창에서 링크 열기 (0) | 2020.11.07 |
---|---|
부트 스트랩에서 열 고정 위치 만들기 (0) | 2020.11.07 |
초 정수를 HH : MM, iPhone으로 변환 (0) | 2020.11.06 |
자바 : 긴 비트가 0 또는 1인지 확인 (0) | 2020.11.06 |
Date 개체에 요일 추가 (0) | 2020.11.06 |