> pip install qdict
Mengeksekusi kueri pada Iterable (List[dict], dict, List[Tuple[key, value]]) dan menerapkan filter.
Filter diterapkan secara horizontal mengikuti iterasi kunci kueri, yaitu, ketika kueri memiliki kunci dan kunci ini bukan operator dan nilainya adalah kamus, kamus ini diisolasi dari dalam kueri dan objek yang akan diperiksa .
Perhatian: Jika objek tidak memiliki kunci yang ditentukan dalam kueri, objek tidak akan dikembalikan pada hasil akhir.
Semua operator menghormati level objek.
$or : daftar pertanyaan.
from qdict import find
obj = [{ "a" : 1 , "b" : { "c" : "Positive" }}, { "a" : 1 , "b" : { "c" : "Negative" }},
{ "a" : 1 , "b" : { "c" : "Undefined" }}, { "a" : 1 }]
result = find ( obj , {
"$or" : [{ "b" : { "c" : "Positive" }},
{ "$not" : { "$has" : "b" }}]
})
r = list ( result )
print ( r ) # [{'a': 1, 'b': {'c': 'Positive'}}, {'a': 1}]
$not : ekspresi negatif
{ "a" : { "$not" : 1 }}
$custom : Mendefinisikan metode secara dinamis. (fungsi, nama kunci1, nama kunci2, ..., nama kunciN). Setiap nama kunci akan menjadi parameter dengan nilai kunci atau Tidak Ada
from qdict import find
obj = [
{ "a" : 1 , "b" : True , "c" : { "a" : 1 }, "d" : { "a" : 1 }},
{ "a" : 3 , "b" : False , "c" : { "a" : 6 }}
]
def pair ( num ):
return num % 2 == 0
query = {
"c" : { "$custom" : ( pair , "a" )}
}
print ( list ( find ( obj , query ))) # [{"a": 3, "b": False, "c": {"a": 6}}]
$has : memeriksa apakah objek berisi kunci
$contains : Jika daftar (objek) berisi item (kueri)
$in : Jika nilai (objek) terdapat dalam daftar (query)
from qdict import find
# simple search
obj = [{ "a" : 1 , "b" : False }, { "a" : 2 , "b" : True }, { "b" : True }]
result = find ( obj , { "b" : True })
print ( list ( result )) # [{'a': 2, 'b': True}, {'a': 3, 'b': True}]
result = find ( obj , { "$has" : "a" })
print ( list ( result )) # [{'a': 1, 'b': False}, {'a': 2, 'b': True}]
result = find ( obj , { "$not" : { "$has" : "a" }})
print ( list ( result )) # [{'b': True}]
# search with subkeys
obj = [{ "a" : 1 , "b" : { "c" : "Positive" }}, { "a" : 1 , "b" : { "c" : "Negative" }},
{ "a" : 1 , "b" : {}}]
result = find ( obj , { "b" : { "c" : "Negative" }})
print ( list ( result )) # [{'a': 1, 'b': {'c': 'Negative'}}]
# $or
obj = [{ "a" : 1 , "b" : { "c" : "Positive" }}, { "a" : 1 , "b" : { "c" : "Negative" }},
{ "a" : 1 , "b" : { "c" : "Undefined" }}, { "a" : 1 }]
result = find ( obj , {
"$or" : [{ "b" : { "c" : "Positive" }},
{ "$not" : { "$has" : "b" }}]
})
print ( list ( result )) # [{'a': 1, 'b': {'c': 'Positive'}}, {'a': 1}]