我有以下......
JArray clients = (JArray)clientsParsed["objects"];
foreach (JObject item in clients.Children())
{
// etc.. SQL params stuff...
command.Parameters["@MyParameter"].Value = JTokenToSql(item["thisParameter"]);
}
Run Code Online (Sandbox Code Playgroud)
JTokenToSql
看起来像这样......
public static object JTokenToSql(JToken obj)
{
if (obj.Any())
return (object)obj;
else
return (object)DBNull.Value;
}
Run Code Online (Sandbox Code Playgroud)
我也试过((JObject)obj).Count
..但似乎没有工作.
Bri*_*ers 138
要检查a上是否存在属性JObject
,可以使用方括号语法并查看结果是否为null.如果属性存在,JToken
则将始终返回a(即使它具有null
JSON中的值).
JToken token = jObject["param"];
if (token != null)
{
// the "param" property exists
}
Run Code Online (Sandbox Code Playgroud)
如果你有一个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);
}
}
Run Code Online (Sandbox Code Playgroud)
Sam*_*ugi 41
您可以按以下步骤检查JToken值是否为空
JToken token = jObject["key"];
if(token.Type == JTokenType.Null)
{
// Do your logic
}
Run Code Online (Sandbox Code Playgroud)
还有一种类型 - JTokenType.Undefined。
此检查必须包含在@Brian Rogers 答案中。
token.Type == JTokenType.Undefined
Run Code Online (Sandbox Code Playgroud)