Python查找不限層級(jí)Json數(shù)據(jù)中某個(gè)key或者value的路徑方式
最近項(xiàng)目中有一個(gè)小需求,查找json文件中某個(gè)key或者value的路徑,所以就寫(xiě)了一個(gè)簡(jiǎn)單的小腳本,比較粗糙。
#!/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('請(qǐng)輸入json格式數(shù)據(jù)')
exit()
if isinstance(data, str):
try:
self.data = ast.literal_eval(data)
except:
logger.error('請(qǐng)輸入正確的json格式數(shù)據(jù)')
exit()
elif isinstance(data, dict):
self.data = data
def __paths(self, data, path=''):
'''
用于遍歷json樹(shù)
:param data: 原始數(shù)據(jù),或者key對(duì)應(yīng)的value值
:param path: key值字符串,默認(rèn)值為''
: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):
'''
查找某個(gè)值的路徑
:param key: 需要查找的值,限制為字符串,數(shù)字,浮點(diǎn)數(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)
補(bǔ)充拓展:python 獲取的json字符串取值
獲取到的json字符串,然后對(duì)其取值
{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查找不限層級(jí)Json數(shù)據(jù)中某個(gè)key或者value的路徑方式就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 關(guān)于python實(shí)現(xiàn)json/字典數(shù)據(jù)中所有key路徑拼接組合問(wèn)題
- Python文件操作JSON CSV TSV Excel和Pickle文件序列化
- Python開(kāi)發(fā)寶典CSV JSON數(shù)據(jù)處理技巧詳解
- Python中如何快速解析JSON對(duì)象數(shù)組
- Python中數(shù)據(jù)類(lèi)轉(zhuǎn)換為JSON的方法詳解
- Python存儲(chǔ)json數(shù)據(jù)發(fā)生亂碼的解決方法
- 使用Python讀取json文件的方法小結(jié)
- python Aligo庫(kù)設(shè)置json路徑使用詳解
相關(guān)文章
Python pickle模塊實(shí)現(xiàn)對(duì)象序列化
這篇文章主要介紹了Python pickle模塊實(shí)現(xiàn)對(duì)象序列化,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11
python實(shí)現(xiàn)簡(jiǎn)單名片管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)簡(jiǎn)單名片管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11
TensorFlow實(shí)現(xiàn)卷積神經(jīng)網(wǎng)絡(luò)CNN
這篇文章主要為大家詳細(xì)介紹了TensorFlow實(shí)現(xiàn)卷積神經(jīng)網(wǎng)絡(luò)CNN,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03
python實(shí)踐項(xiàng)目之監(jiān)控當(dāng)前聯(lián)網(wǎng)狀態(tài)詳情
介紹一個(gè)利用Python監(jiān)控當(dāng)前聯(lián)網(wǎng)狀態(tài)情況的python代碼,它可以清楚地知道,你的電腦網(wǎng)絡(luò)是否是鏈接成功或失敗,下面小編帶大家來(lái)一起學(xué)習(xí)它2019-05-05
SQLite5-使用Python來(lái)讀寫(xiě)數(shù)據(jù)庫(kù)
這篇文章主要介紹了SQLite5-使用Python來(lái)讀寫(xiě)數(shù)據(jù)庫(kù),數(shù)據(jù)庫(kù)的實(shí)際應(yīng)用,通常需要與程序結(jié)合起來(lái),通過(guò)程序來(lái)實(shí)現(xiàn)對(duì)數(shù)據(jù)庫(kù)的訪問(wèn)和讀寫(xiě)。本篇先介紹Python語(yǔ)言來(lái)調(diào)用SQLite數(shù)據(jù)庫(kù),想具體了解的小伙伴可以參考一下</P><P>2021-12-12
python進(jìn)行相關(guān)性分析并繪制散點(diǎn)圖詳解
這篇文章主要介紹了python進(jìn)行相關(guān)性分析并繪制散點(diǎn)圖,具有一定借鑒價(jià)值,需要的朋友可以參考下,希望能夠給你帶來(lái)幫助2021-09-09
python實(shí)現(xiàn)飛機(jī)大戰(zhàn)項(xiàng)目
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)飛機(jī)大戰(zhàn)項(xiàng)目,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03

