首页 > 解决方案 > 递归替换dict键中的字符

问题描述

我目前正在编写一个脚本,它将 Android 应用程序的元数据作为嵌套字典并将其插入到 MongoDB。但是,由于某些键包含'.'s(由于 APK 文件中的组件名称),不幸的是,MongoDB在正在处理的版本中不接受它。目前正在尝试编写一个递归脚本,将 s 替换为'.'s'/'插入的 dict 数据中的键,但某些键仍然没有更改以满足要求。

def fixKeys(dictionary):
    for k,v in dictionary.items():
        if isinstance(v, dict):
            if '.' in k:
                dictionary[k.replace('.','/')] = dictionary.pop(k)
            fixKeys(v)
        else:
            if '.' in k:
                dictionary[k.replace('.','/')] = dictionary.pop(k)
    return dictionary 

示例输入:

data = {"gender":"male","name.data": {"last.name":"Arabulut","first.name":"Altay","parents.names":{"father.name":"John","mother.name":"Jennifer"}}, "birthday.data":{"birthday.day":"01","birthday.month":"03","birthday.year":"1977"}}

关于可能缺少什么的任何想法?

标签: pythonmongodbdictionaryrecursion

解决方案


编辑后我更正确地理解了你的问题,未知数量的嵌套字典的递归解决方案如下:

def fixKeys(dictionary):
    for k,v in list(dictionary.items()):
        if isinstance(v, dict):
            dictionary[k.replace('.', '/')] = fixKeys(v)
        else:
            dictionary[k.replace('.', '/')] = v
        if "." in k:
            dictionary.pop(k)
    return dictionary

m_dict = {"gender":"male", "name.data": {"last.name":"Arabulut","first.name":"Altay","parents.names":{"father.name":"John","mother.name":"Jennifer"}}, "birthday.data":{"birthday.day":"01","birthday.month":"03","birthday.year":"1977"}}

new_dict = fixKeys(m_dict)
print(str(new_dict))

输出:

{'gender': 'male', 'name/data': {'last/name': 'Arabulut', 'first/name': 'Altay', 'parents/names': {'father/name': 'John', 'mother/name': 'Jennifer'}}, 'birthday/data': {'birthday/day': '01', 'birthday/month': '03', 'birthday/year': '1977'}}

很好的问题。喜欢编码和调试!


推荐阅读