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) 
+0

你似乎已经遗漏了一些单词。问题是什么? – khelwood

+0

我会编辑问题,但简单地说,问题是,当我从加载的json文件中搜索对象,并尝试将匹配值与搜索参数匹配时,它永远不匹配。 我可以导航并打印对象,但该值永远不会匹配要搜索的参数。 – user1820904

的问题是我驾驶的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) 

希望这可以帮助别人。