Memeriksa JToken kosong atau nol di JObject

90

Saya memiliki yang berikut ...

JArray clients = (JArray)clientsParsed["objects"];

foreach (JObject item in clients.Children())
{
    // etc.. SQL params stuff...
    command.Parameters["@MyParameter"].Value = JTokenToSql(item["thisParameter"]);
}

JTokenToSql terlihat seperti ini...

public static object JTokenToSql(JToken obj)
{
    if (obj.Any())
        return (object)obj;
    else
        return (object)DBNull.Value;
}

Saya juga sudah mencoba ((JObject)obj).Count.. Tapi sepertinya tidak berhasil.

Kyle
sumber

Jawaban:

177

Untuk memeriksa apakah sebuah properti ada di a JObject, Anda dapat menggunakan sintaks kurung siku dan melihat apakah hasilnya null atau tidak. Jika properti ada, a JTokenakan selalu dikembalikan (meskipun memiliki nilai nulldi JSON).

JToken token = jObject["param"];
if (token != null)
{
    // the "param" property exists
}

Jika Anda memiliki JTokendi tangan dan Anda ingin melihat apakah itu tidak kosong, itu tergantung pada jenisnya JTokendan bagaimana Anda mendefinisikan "kosong". Saya biasanya menggunakan metode ekstensi seperti ini:

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);
    }
}
Brian Rogers
sumber
1
Saya akan membuatnya metode ekstensi seperti: public static bool IsNullOrEmpty (token JToken ini) {...} untuk digunakan seperti JToken token = jObject ["param"]; bool kosong = token.IsNullOrEmpty ()
Dmitry Pavlov
1
Bisakah Anda tidak ToSrtingyang JTokendan periksa IsNullOrWhiteSpace? (Setelah memeriksa JTokententu saja tidak null)
Coops
1
@CodeBlend Itu tidak akan berfungsi untuk objek atau array - versi serial dari yang kosong adalah {}dan []masing - masing.
Brian Rogers
1
Saya akan menambahkan Pemeriksaan properti: 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) || (token.Type == JTokenType.Property && ((JProperty) token] .Value.ToString () == string.Empty);
jcmontx
60

Anda dapat melanjutkan sebagai berikut untuk memeriksa apakah Nilai JToken adalah null

JToken token = jObject["key"];

if(token.Type == JTokenType.Null)
{
    // Do your logic
}
Sam Ngugi
sumber
3
Persis apa yang saya cari, karena parameter kosong mengembalikan tipe null yang melewati perbandingan khas == null. Terima kasih!
Tim Tyler
4

Ada juga tipe - JTokenType.Undefined.

Cek ini harus dimasukkan dalam jawaban @Brian Rogers.

token.Type == JTokenType.Undefined
aleha
sumber
1

Mulai C # 7 Anda juga bisa menggunakan ini:

if (clientsParsed["objects"] is JArray clients) 
{
    foreach (JObject item in clients.Children())
    {
        if (item["thisParameter"] as JToken itemToken) 
        {
            command.Parameters["@MyParameter"].Value = JTokenToSql(itemToken);
        }
    }
}

Operator is memeriksa Jenis dan jika mengoreksi Nilai ada di dalam variabel klien.

Sebastian
sumber
0

Coba sesuatu seperti ini untuk mengonversi JToken ke 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
}
cinta hidup
sumber