递归地遍历带有列表的嵌套字典,并替换匹配的值

时间:2019-04-16 17:44:23

标签: python json python-3.x dictionary recursion

我想做一个通过包含列表的嵌套字典迭代的函数。对于每个与关键字匹配的值,该函数将其替换为另一个关键字。

该函数返回另一个字典或更改主字典并不重要。

我试图将案件分开: -如果数据是字典,那么做点什么 -如果数据是列表,则另做一遍

DICT:


data_dict = {
  "name": "AAAAAA",
  "content": "BBBBBB",
  "dat": [
    {
      "author": {
        "name": "CCCCCC",
        "surname": "DDDDDD",
      },
      "title": "FFFFFF",
      "color": 15258703,
      "fields": [
        {
          "name": "GGGGGG",
          "value": "HHHHHH",
        },
        {
          "name": "IIIIII",
          "value": "JJJJJJ",
        }

      ],
      "thumbnail": {
        "url": "KKKKKK"
      },
      "image": {
        "url": "LLLLLL"
      },
      "footer": {
        "text": "MMMMMMM",
        "icon_url": "NNNNNN"
      }
    }
  ]
}


现在,我只是尝试更改每个值,以查看是否也要进行迭代。 我可以打印所有更改了值的data_dict,但无法在字典中对其进行管理...


def recursive_replace_valuer(data, match, repl):

    if isinstance(data, list):
        for l in data:
            recursive_replace_valuer(l, match, repl)
            if isinstance(l, dict):
                recursive_replace_valuer(l, match, repl)




    elif isinstance(data, dict):
        for k,v in data.items():
            recursive_replace_valuer(v, match, repl)
            data[k] = '______'
        print(data)

recursive_replace_valuer(data_dict, 'a','a')

1 个答案:

答案 0 :(得分:1)

该函数应将其递归地应用于字典或列表中的值,直到输入data既不是字典也不是列表,此时如果给定,则返回替换值repl数据与给定的搜索字符串match相匹配:

def replace(data, match, repl):
    if isinstance(data, dict):
        return {k: replace(v, match, repl) for k, v in data.items()}
    elif isinstance(data, list):
        return [replace(i, match, repl) for i in data]
    else:
        return repl if data == match else data

或者就地替换原始数据,使函数在给定的dict或list上进行迭代,并在匹配时用键(对dict)或索引(对list)替换值,然后递归应用该函数值:

def replace(data, match, repl):
    if isinstance(data, (dict, list)):
        for k, v in (data.items() if isinstance(data, dict) else enumerate(data)):
            if v == match:
                data[k] = repl
            replace(v, match, repl)