python - 在 Python 中递归地转换字典

标签 python dictionary recursion

这是一本字典:

data = {
    'a': {
        'b': {
            'c': {
                'd': {
                    'e': {
                        'f': 1,
                        'g': 50,
                        'h': [1, 2, 4],
                        'i': 3,
                        'j': [7, 9, 6],
                        'k': [
                            [('x', 'abc')],
                            [('y', 'qwe')],
                            [('z', 'zxc')]
                        ]
                    }
                }
            }
        }
    }
}

我的目标是尽可能找到值并将其转换为字典:

data = {
    'a': {
        'b': {
            'c': {
                'd': {
                    'e': {
                        'f': 1,
                        'g': 50,
                        'h': [1, 2, 4],
                        'i': 3,
                        'j': [7, 9, 6],
                        'k': [{
                            'x': 'abc'
                        }, {
                            'y': 'qwe'
                        }, {
                            'z': 'zxc'
                        }]
                    }
                }
            }
        }
    }
}

我认为这可以使用递归来完成,我什至写了一个,但它不起作用。

def f(d):
  for key, value in d.iteritems():
    if type(d[key]) is dict:
      f(d)

    try:
      d[key] = dict(d[key])
    except:
      if type(d[key]) is list:
        for i in d[key]:
          try:
            d[key][i] = dict(d[key][i])
          except:
            pass

  return d

错误:

RecursionError: maximum recursion depth exceeded while calling a Python object

如何让它发挥作用?

如果你能提供一个不用递归的解决方案,我也很乐意得到它。

最佳答案

你的程序中有一堆错误,让我们检查它们并提出一个工作版本。

def f(d):
  for key, value in d.iteritems():
    if type(d[key]) is dict:
      f(d)                        # You should call d[key] instead 
    try:
      d[key] = dict(d[key])       # Never assign an object back to the one you are iterating over, create a new object instead.
    except:
      if type(d[key]) is list:
        for i in d[key]:
          try:
            d[key][i] = dict(d[key][i])  # This doesn't work, can't convert a tuple/list this way.
          except:
            pass

  return d

这是带有两个递归函数的代码的更正版本。一个用于列表,另一个用于字典。

def f1(value):
  e = []
  for val in value:
    if type(val) is list:
      e += f1(val)               # Append list to current list
    elif type(val) is tuple:
      e.append({val[0]: val[1]}) # Convert tuple to dictionary
    else:
      e.append(val)              # Append normal list values normally
  return e

def f(d, e  = {}):
  for key, value in d.iteritems():
    if type(value) is dict:
      e[key] = f(value, {})     # Recurse for dictionaries
    elif type(value) is list:
      e[key] = f1(value)        # Call the other recursive function for list
    else:
      e[key] = value            # Otherwise like strings and ints just append
  return e

在这里测试:https://repl.it/LDKn/0

关于python - 在 Python 中递归地转换字典,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46181365/

相关文章:

python - Python3.0动态导入模块?

python - 如何根据 python 上的 tkinter 中的用户输入生成弹出消息?

c# - Dictionary.Item 和 Dictionary.Add 之间有什么区别?

java - 从 HashMap 中提取一个元素并更新它

java - 这会导致堆栈溢出错误吗?

python - 如何强制 Pycharm 运行所有单元测试?

python - 是否可以在 sklearn 中组合多个部分拟合估计量?

swift - 如何声明具有结构值的字典

php - 用于递归结果的 Laravel 查询构建器?例如。 id, parent_id

java - 通过递归调用继续存储变量值