Python 2.7:加载JSON文件搜索一个值,替换它,并保存为新的JSON
问题描述:
正如标题中提到的,我试图做一个简单的py脚本,可以从终端运行以下操作:Python 2.7:加载JSON文件搜索一个值,替换它,并保存为新的JSON
- 查找当前工作目录和嵌套的文件夹的所有JSON文件(这部分工作得很好)
- 负荷说文件
- 递归搜索他们的特定值或子
- 如果该值匹配,将其替换为用户新建立的值
- 完成后,将所有已修改的json文件保存到当前目录中的“已转换”文件夹中。
这就是说,问题是当我尝试下面发布的递归搜索方法,因为我几乎是新的python我将不胜感激任何帮助这个问题,我想它是...或者我正在使用的json文件或我正在使用的搜索方法。
简化问题,我搜索的值永远不会与对象内的任何内容相匹配,可能是某个键或纯粹的某个字符串值。尝试了多种方法来执行递归搜索,但无法获得匹配结果。例如:考虑到示例json,我想在结构“1h_mod310_door_00”中替换值“selectable_parts”或“static_parts”或更深,但似乎我的搜索方法无法达到此值“object [object] [children] [0] [children] [5] [name]”(希望这有助于)。
样品JSON:(https://drive.google.com/open?id=0B2-Bn2b0ujjVdW5YVGg3REg3OWs)
"""KEYWORD REPLACING MODULE."""
import os
import json
# functions
def get_files():
"""lists files"""
exclude = set(['.vscode', 'sample'])
json_files = []
for root, dirs, files in os.walk(os.getcwd(), topdown=True):
dirs[:] = [d for d in dirs if d not in exclude]
for name in files:
if name.endswith('.json'):
json_files.append(os.path.join(root, name))
return json_files
def load_files(json_files):
"""works files"""
for js_file in json_files:
with open(js_file) as json_file:
loaded_json = json.load(json_file)
replace_key_value(loaded_json, os.path.basename(js_file))
def write_file(data_file, new_file_name):
"""writes the file"""
if not os.path.exists('converted'):
os.makedirs('converted')
with open('converted/' + new_file_name, 'w') as json_file:
json.dump(data_file, json_file)
def replace_key_value(js_file, js_file_name):
"""replace and initiate save"""
recursive_replace(js_file, SKEY, '')
# write_file(js_file, js_file_name)
def recursive_replace(data, match, repl):
"""search for needed value and replace its value"""
for key, value in data.items():
if value == match:
print data[key]
print "AHHHHHHHH"
elif isinstance(value, dict):
recursive_replace(value, match, repl)
# main
print "\n" + '- on ' + os.getcwd()
NEW_DIR = raw_input('Work dir (leave empty if current): ')
if not NEW_DIR:
print NEW_DIR
NEW_DIR = os.getcwd()
else:
print NEW_DIR
os.chdir(NEW_DIR)
# get_files()
JS_FILES = get_files()
print '- files on ' + os.getcwd()
# print "\n".join(JS_FILES)
SKEY = raw_input('Value to search: ')
RKEY = raw_input('Replacement value: ')
load_files(JS_FILES)
答
的问题是我驾驶的JSON OBJ,因为该方法没有体贴,如果它是一个字典或列表(我相信的样子.. )。
因此,要回答我的问题,这里的递归搜索我使用的检查值:
def get_recursively(search_dict, field):
"""
Takes a dict with nested lists and dicts,
and searches all dicts for a key of the field
provided.
"""
fields_found = []
for key, value in search_dict.iteritems():
if key == field:
print value
fields_found.append(value)
elif isinstance(value, dict):
results = get_recursively(value, field)
for result in results:
if SEARCH_KEY in result:
fields_found.append(result)
elif isinstance(value, list):
for item in value:
if isinstance(item, dict):
more_results = get_recursively(item, field)
for another_result in more_results:
if SEARCH_KEY in another_result:
fields_found.append(another_result)
return fields_found
# write_file(js_file, js_file_name)
希望这可以帮助别人。
你似乎已经遗漏了一些单词。问题是什么? – khelwood
我会编辑问题,但简单地说,问题是,当我从加载的json文件中搜索对象,并尝试将匹配值与搜索参数匹配时,它永远不匹配。 我可以导航并打印对象,但该值永远不会匹配要搜索的参数。 – user1820904