我有以下...
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。如果该属性存在,将始终返回一个 JToken
(即使它在 JSON 中的值为 null
)。
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);
}
}
关于c# - 检查 JObject 中的空 JToken 或空 JToken,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24066400/