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