Python查找不限層級Json數(shù)據(jù)中某個key或者value的路徑方式
最近項目中有一個小需求,查找json文件中某個key或者value的路徑,所以就寫了一個簡單的小腳本,比較粗糙。
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
'''
@author: funcups
'''
from logzero import logger
import ast
class HandleJson():
def __init__(self, data):
if data == None:
logger.error('請輸入json格式數(shù)據(jù)')
exit()
if isinstance(data, str):
try:
self.data = ast.literal_eval(data)
except:
logger.error('請輸入正確的json格式數(shù)據(jù)')
exit()
elif isinstance(data, dict):
self.data = data
def __paths(self, data, path=''):
'''
用于遍歷json樹
:param data: 原始數(shù)據(jù),或者key對應的value值
:param path: key值字符串,默認值為''
:return:
'''
if isinstance(data, dict):
for k, v in data.items():
tmp = path + "['%s']" % k
yield (tmp, v)
yield from self.__paths(v, tmp)
if isinstance(data, list):
for k, v in enumerate(data):
tmp = path + '[%d]' % k
yield (tmp, v)
yield from self.__paths(v, tmp)
def find_key_path(self, key):
'''
查找key路徑
:param key: 需要查找路徑的key值
:return: 包含key值路徑的list
'''
result = []
for path,value in self.__paths(self.data):
if path.endswith("['%s']" % key):
result.append(path)
with open('path.txt', 'w+', encoding='utf-8') as f:
list(map(lambda line: f.write(line + '\r'), result))
return result
def find_value_path(self, key):
'''
查找某個值的路徑
:param key: 需要查找的值,限制為字符串,數(shù)字,浮點數(shù),布爾值
:return:
'''
result = []
for path, value in self.__paths(self.data):
if isinstance(value, (str, int, bool, float)):
if value == key:
result.append(path)
with open('path.txt', 'w+', encoding='utf-8') as f:
list(map(lambda line: f.write(line + '\r'), result))
return result
if __name__ == '__main__':
data = {'name': 'funcups'}
hj = HandleJson(data)
res = hj.find_key_path('name')
print(res)
res = hj.find_value_path('funcups')
print(res)
補充拓展:python 獲取的json字符串取值
獲取到的json字符串,然后對其取值
{u'result': {u'10.10.10.100': {u'status': u'OK', u'msg': u"{'listen': {'': set([]), '25': set([]),
'22': set(['10.9.19.148', '10.10.10.1', '10.10.10.130'])}}"}}}
data = result.get('result').get(ip[0]).get('msg')
取值得到的是unicode字符串
轉(zhuǎn)換為字典 可用eval()函數(shù)
data = eval(result.get('result').get(ip[0]).get('msg'))
data = data.get('listen')
以上這篇Python查找不限層級Json數(shù)據(jù)中某個key或者value的路徑方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
TensorFlow實現(xiàn)卷積神經(jīng)網(wǎng)絡CNN
這篇文章主要為大家詳細介紹了TensorFlow實現(xiàn)卷積神經(jīng)網(wǎng)絡CNN,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-03-03
python實踐項目之監(jiān)控當前聯(lián)網(wǎng)狀態(tài)詳情
介紹一個利用Python監(jiān)控當前聯(lián)網(wǎng)狀態(tài)情況的python代碼,它可以清楚地知道,你的電腦網(wǎng)絡是否是鏈接成功或失敗,下面小編帶大家來一起學習它2019-05-05
SQLite5-使用Python來讀寫數(shù)據(jù)庫
這篇文章主要介紹了SQLite5-使用Python來讀寫數(shù)據(jù)庫,數(shù)據(jù)庫的實際應用,通常需要與程序結(jié)合起來,通過程序來實現(xiàn)對數(shù)據(jù)庫的訪問和讀寫。本篇先介紹Python語言來調(diào)用SQLite數(shù)據(jù)庫,想具體了解的小伙伴可以參考一下</P><P>2021-12-12

