JSONPARSE是一個簡單的JSON解析庫。從密鑰中提取所需的內容:價值對。
pip install jsonparse這是JSONPARSE能夠做什麼的快速示例。
from jsonparse import find_key , find_keys , find_key_chain , find_key_value , find_value
data = [{
"key0" :
{
"key1" : "result" ,
"key2" :
{
"key1" : "result1" ,
"key3" : { "key1" : "result2" }
}
}
}]
find_key ( data , 'key1' )
[ 'result2' , 'result1' , 'result' ]
find_key_chain ( data , [ 'key0' , 'key2' , 'key3' , 'key1' ])
[ 'result2' ]➕請參閱下面的API部分中的其他文檔。
pip install jsonparse CLI命令的摘要。有關完整的信息, jp --help
請注意, jsonparse和jp是等效的。
jp key key1 --file text.json
jp keys key1 key2 key3 --file text.json
jp key-chain my '*' chain --file text.json
jp key-value key1 '"result"' --file text.json
echo '{"key1": {"key2": 5}}' | jp key key2
jp value null --file text.json
jp value 42 --file text.json
jp value '"strValue"' --file text.json
使用以下測試數據的API示例。
data = [
{ "key" : 1 },
{ "key" : 2 },
{ "my" :
{ "key" :
{
"chain" : "A" ,
"rope" : 5 ,
"string" : 1.2 ,
"cable" : False
}
}
},
{ "your" :
{ "key" :
{
"chain" : "B" ,
"rope" : 7 ,
"string" : 0.7 ,
"cable" : True
}
}
}
] from jsonparse import find_key , find_keys , find_key_chain , find_key_value , find_valuefind_key(數據:dict | list | ordereddict,鍵:str ) - >列表
將返回匹配鍵的所有值。
find_key ( data , 'chain' )
[ 'A' , 'B' ]
find_key ( data , 'key' )
[ 1 , 2 , { 'chain' : 'A' , 'rope' : 5 , 'string' : 1.2 , 'cable' : False }, { 'chain' : 'B' , 'rope' : 7 , 'string' : 0.7 , 'cable' : True }]find_keys(數據:dict | list | ordereddict,鍵:列表,組:bool = true ) - > list
默認返回值是二維列表。 [ [], [], ...] 。
要返回所有值作為一個維列表,請設置group=False 。
鑰匙的順序無關緊要。
find_keys ( data , [ 'rope' , 'cable' ])
[[ 5 , False ], [ 7 , True ]]
find_keys ( data , [ 'rope' , 'cable' ], group = False )
[ 5 , False , 7 , True ]find_key_chain(數據:dict | list | orderddict,鍵:列表) - >列表
鑰匙鍊是鍵的有序列表。該鏈需要從嵌套數據的根級開始。
通配符*可以用作匹配任何鍵的鑰匙。
find_key_chain ( data , [ 'my' , 'key' , 'chain' ])
[ 'A' ]
find_key_chain ( data , [ 'key' ])
[ 1 , 2 ]
find_key_chain ( data , [ '*' , 'key' , 'chain' ])
[ 'A' , 'B' ]
find_key_chain ( data , [ '*' , 'key' , '*' ])
[ 'A' , 5 , 1.2 , False , 'B' , 7 , 0.7 , True ]find_key_value(數據:dict | list | ordereddict,鍵:str, value :str | int | float | bool | bool | none) - >列表
返回的列表包含包含指定鍵的字典:值對。
find_key_value ( data , 'cable' , False )
[{ 'chain' : 'A' , 'rope' : 5 , 'string' : 1.2 , 'cable' : False }]
find_key_value ( data , 'chain' , 'B' )
[{ 'chain' : 'B' , 'rope' : 7 , 'string' : 0.7 , 'cable' : True }]find_value(數據:dict | list | ordereddict, value :str | int | float | bool | none ) - >列表
將返回匹配值的所有鍵。
find_value ( data , 'A' )
[ 'chain' ]
find_value ( data , False )
[ 'cable' ]訪問Swagger API文檔
所有端點都是HTTP POST請求,其中您在請求正文中包含可搜索的JSON數據。
POST /v1/key/{key}
POST /v1/keys ? key=1 & key=2 & key=3 & key=4...
POST /v1/keychain ? key=1 & key=2 & key=3 & key=4...
POST /v1/keyvalue ? key=a & value=1
POST /v1/value/{value}讓我們練習使用公共,免費使用的非認證,在GCP Cloud運行中託管的Web API。
我們正在用捲髮發布JSON數據,要求搜索鍵“ key1”。找到的關鍵值將返回為JSON。
curl -X POST " https://jsonparse.dev/v1/key/key1 "
-H ' Content-Type: application/json '
-d ' [{"key0":{"key1":"result","key2":{"key1":"result1","key3":{"key1":"result2"}}}}] '
[ " result2 " , " result1 " , " result " ]或(使用Python和請求庫)
import requests
data = [{
"key0" :
{
"key1" : "result" ,
"key2" :
{
"key1" : "result1" ,
"key3" : { "key1" : "result2" }
}
}
}]
requests . post ( 'https://jsonparse.dev/v1/key/key1' , json = data ). json ()
[ 'result2' , 'result1' , 'result' ]pip install " jsonparse[webapi] "
gunicorn -b 0.0.0.0:8000 jsonparse.webapi:app或者,運行Docker容器
docker run -d ctomkow/jsonparse