【发布时间】:2015-12-15 16:30:50
【问题描述】:
我需要一个字典数据结构来存储字典,如下所示:
custom = {1: {'a': np.zeros(10), 'b': np.zeros(100)},
2: {'c': np.zeros(20), 'd': np.zeros(200)}}
但问题是我在代码中多次迭代这个数据结构。每次迭代它时,我都需要遵守迭代顺序,因为这个复杂数据结构中的所有元素都映射到一维数组(如果愿意,可以序列化),因此顺序很重要。我想过为此写一个有序的dict 或有序的dict,但我不确定这是正确的解决方案,因为我可能选择了错误的数据结构。对于我的情况,最合适的解决方案是什么?
更新
这就是我目前想出的:
class Test(list):
def __init__(self, *args, **kwargs):
super(Test, self).__init__(*args, **kwargs)
for k,v in args[0].items():
self[k] = OrderedDict(v)
self.d = -1
self.iterator = iter(self[-1].keys())
self.etype = next(self.iterator)
self.idx = 0
def __iter__(self):
return self
def __next__(self):
try:
self.idx += 1
return self[self.d][self.etype][self.idx-1]
except IndexError:
self.etype = next(self.iterator)
self.idx = 0
return self[self.d][self.etype][self.idx-1]
def __call__(self, d):
self.d = -1 - d
self.iterator = iter(self[self.d].keys())
self.etype = next(self.iterator)
self.idx = 0
return self
def main(argv=()):
tst = Test(elements)
for el in tst:
print(el)
# loop over a lower dimension
for el in tst(-2):
print(el)
print(tst)
return 0
if __name__ == "__main__":
sys.exit(main())
我可以在这个有序结构中迭代任意多次,并且我实现了__call__,因此我可以迭代较低的维度。我不喜欢这样一个事实,即如果列表中没有较低的维度,它不会给我任何错误。我也觉得每次调用return self[self.d][self.etype][self.idx-1] 的效率都低于字典上的原始迭代。这是真的?我该如何改进?
【问题讨论】:
标签: python dictionary