高效处理Python深度嵌套字典
在处理JSON数据或其他涉及深度嵌套字典的Python程序中,直接访问和修改深层嵌套的值往往繁琐冗长。本文介绍一种更优雅的方法,避免冗余代码,并改进现有的dotdictify解决方案。
原始dotdictify方案的不足之处在于,访问不存在的键时返回None,这可能掩盖真正的KeyError,增加调试难度。 因此,我们需要改进其__getitem__方法,使其在访问不存在的键时抛出KeyError,更符合Python的异常处理机制。
此外,为了支持更直观的点表示法(例如my_obj.a.b.c),我们需要修改__setitem__和__getitem__方法,使其能够解析点分隔的键,并在必要时创建中间字典。
立即学习“Python免费学习笔记(深入)”;
以下代码展示了改进后的dotdictify类:
class dotdictify(dict): def __init__(self, value=None): if value is None: pass elif isinstance(value, dict): for key in value: self.__setitem__(key, value[key]) else: raise TypeError('expected dict') def __setitem__(self, key, value): if '.' in key: parts = key.split('.', 1) target = self.setdefault(parts[0], dotdictify()) if not isinstance(target, dotdictify): raise KeyError(f'Cannot set "{parts[1]}" in "{parts[0]}" ({repr(target)})') target[parts[1]] = value else: if isinstance(value, dict) and not isinstance(value, dotdictify): value = dotdictify(value) dict.__setitem__(self, key, value) def __getitem__(self, key): if '.' not in key: return dict.__getitem__(self, key) parts = key.split('.', 1) target = dict.__getitem__(self, parts[0]) if not isinstance(target, dotdictify): raise KeyError(f'Cannot get "{parts[1]}" in "{parts[0]}" ({repr(target)})') return target[parts[1]] def __contains__(self, key): if '.' not in key: return dict.__contains__(self, key) parts = key.split('.', 1) target = dict.__getitem__(self, parts[0]) if not isinstance(target, dotdictify): return False return parts[1] in target def setdefault(self, key, default): if key not in self: self[key] = default return self[key] __setattr__ = __setitem__ __getattr__ = __getitem__
登录后复制
此改进后的dotdictify类支持点表示法,并在访问不存在的键时抛出KeyError,增强了代码的健壮性和可维护性。 使用此类,可以更轻松地操作深度嵌套字典,提高代码的可读性和效率。 (测试代码示例可根据需要补充)
以上就是如何优雅地访问和修改Python中深度嵌套的字典?的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2526214.html