[英]Checking for empty or null JToken in a JObject
我有以下...
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
also.. 但似乎沒有用。
要檢查JObject
上是否存在屬性,您可以使用方括號語法並查看結果是否為空。 如果該屬性存在,則將始終返回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);
}
}
您可以按照以下步驟檢查 JToken 值是否為空
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
}
您現在可以在 C# 6+ 嘗試使用空條件訪問運算符?[]
直接訪問。
foreach (JObject item in clients.Children())
{
// value will be null if access fails
var value = (string)item?["thisParameter"]?["anotherNode"]?["oneMoreNestedNode"];
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.