这个字典随着键和值不断变化。我想要访问这些键和值并像预期答案一样打印出来。由于我是Python新手,任何帮助都将非常感谢。
dictionary=
{'key1': {'key10': [[66619, 'event1'], [64800, 'event2']]},
'key2': {'key11': [[28250, 'event3'], [17960, 'event4'], [23484, 'event5'], [21945, 'event6']]},
'key3': {'key12': [[359319, 'event7'], [322334, 'event8'], [273316, 'event9']], 'key13': [[452945, 'event10'], [414268, 'event11']]}
}
预期回答:
名称:key1,地址:key10,编号:66619,Pin_code:event1
Name:key1, Address:key10, Number:64800, Pin_code:event2
名称:key2,地址:key11,编号:28250,Pin_code:event3
名称:key2,地址:key11,号码:17960,Pin_code:event4
姓名:key2,地址:key11,号码:23484,Pin_code:event5
名称:key2,地址:key11,编号:21945,Pin_code:event6
姓名:key3,地址:key12,号码:359319,Pin_code:event7
姓名:key3,地址:key12,号码:322334,Pin_code:event8
姓名:key3,地址:key12,号码:273316,Pin_code:event9
名称:key3,地址:key13,编号:452945,Pin_code:event10
姓名:key3,地址:key13,号码:414268,Pin_code:event11
字典本质上是无序的。如果你想保持dict
的秩序,你必须使用collections.OrderedDict()
。根据OrderedDict
文件:
返回一个dict子类的实例,支持常规的dict方法。OrderedDict是一个记住键的顺序的字典首先插入。如果新条目覆盖了现有条目,则原始插入位置保持不变。删除条目和重新插入它将把它移到末尾。
如果您只想打印此内容而不实际存储已排序的数据,您可以使用简单的sorted()
函数:
from operator import itemgetter
for k, v in sorted(dictionary.items(), key=itemgetter(0)):
for k1, v1 in sorted(v.items(), key=itemgetter(0)):
for content in v1:
print 'Name: {}, Address: {}, Number: {}, Pin: {}'.format(k, k1, content[0], content[1])
将打印:
Name: key1, Address: key10, Number: 66619, Pin: event1
Name: key1, Address: key10, Number: 64800, Pin: event2
Name: key2, Address: key11, Number: 28250, Pin: event3
Name: key2, Address: key11, Number: 17960, Pin: event4
Name: key2, Address: key11, Number: 23484, Pin: event5
Name: key2, Address: key11, Number: 21945, Pin: event6
Name: key3, Address: key12, Number: 359319, Pin: event7
Name: key3, Address: key12, Number: 322334, Pin: event8
Name: key3, Address: key12, Number: 273316, Pin: event9
Name: key3, Address: key13, Number: 452945, Pin: event10
Name: key3, Address: key13, Number: 414268, Pin: event11