我无法将值附加到嵌套词典中的列表中。我试图跟踪几年来种植在一组田地上的农作物。我的目标是能够以crops[year][field_name]
之类的方式搜索农作物列表。
这是空的数据结构:
{2015: {'CP 4B1': [],
'CP 4D1': [],
'CP 1': [],
'CP 5D': [],
'CP 6C': [],
'CP 3': [],
'CP 4B': [],
'CP 4D': [],
'CP 4A': [],
'CP 4C1': [],
'CP 5C': [],
'CP 6A': [],
'CP 4A1': [],
'EF 4A': [],
'EF 5B': [],
'EF 5A': [],
'EF 1D': [],
'EF 1E': [],
'EF 1C': [],
'ES 6A': [],
'ES 6B': [],
'EF 1A': [],
'EF 1B': [],
'EF 4C': [],
'EF 4B': [],
'FF 1': [],
'FF 2': [],
'FF 3': [],
'HM 11': [],
'HM 1': [],
'HM 16B': [],
'HM 2A': [],
'HM 9C': [],
'HM 9B': [],
'HM 10': [],
'HM 12': [],
'HM 5': [],
'HM 8': [],
'HM 13': [],
'HM 2B': [],
'HM 6': [],
'HF 13': [],
'HF 12': [],
'HF 2A': [],
'HF 15B': [],
'HF 15A': [],
'HF 9': [],
'MC 8': [],
'MC 10': [],
'MC 5': [],
'MC 1': [],
'MC 2': [],
'MC 13': [],
'MC 4': [],
'MC 3': [],
'MC 6': [],
'MC 12': [],
'MC 9': [],
'MC 7': [],
'MC 11A': [],
'MC 11': [],
'MC 14': [],
'MC 14A': [],
'MC 13A': [],
'MC 2A': [],
'RF 2A': [],
'MS 8': [],
'MS 16': [],
'MS 21': [],
'MS 17': [],
'MS 11': [],
'BSF 1B': [],
'BSF 4A': [],
'BSF 3': [],
'BSF 1A': [],
'BSF Orchard': [],
'TF 4': [],
'TF 3B': [],
'TF 3A': [],
'TF 5': [],
'TF 11': [],
'TF 8': [],
'TF 1': [],
'TF 2': [],
'WA 3': [],
'WA 7': [],
'WA 5B': [],
'WA 1': [],
'WA 5A': []},
2016: {'CP 4B1': [],
'CP 4D1': [],
'CP 1': [],
'CP 5D': [],
'CP 6C': [],
'CP 3': [],
'CP 4B': [],
'CP 4D': [],
'CP 4A': [],
'CP 4C1': [],
'CP 5C': [],
'CP 6A': [],
'CP 4A1': [],
'EF 4A': [],
'EF 5B': [],
'EF 5A': [],
'EF 1D': [],
'EF 1E': [],
'EF 1C': [],
'ES 6A': [],
'ES 6B': [],
'EF 1A': [],
'EF 1B': [],
'EF 4C': [],
'EF 4B': [],
'FF 1': [],
'FF 2': [],
'FF 3': [],
'HM 11': [],
'HM 1': [],
'HM 16B': [],
'HM 2A': [],
'HM 9C': [],
'HM 9B': [],
'HM 10': [],
'HM 12': [],
'HM 5': [],
'HM 8': [],
'HM 13': [],
'HM 2B': [],
'HM 6': [],
'HF 13': [],
'HF 12': [],
'HF 2A': [],
'HF 15B': [],
'HF 15A': [],
'HF 9': [],
'MC 8': [],
'MC 10': [],
'MC 5': [],
'MC 1': [],
'MC 2': [],
'MC 13': [],
'MC 4': [],
'MC 3': [],
'MC 6': [],
'MC 12': [],
'MC 9': [],
'MC 7': [],
'MC 11A': [],
'MC 11': [],
'MC 14': [],
'MC 14A': [],
'MC 13A': [],
'MC 2A': [],
'RF 2A': [],
'MS 8': [],
'MS 16': [],
'MS 21': [],
'MS 17': [],
'MS 11': [],
'BSF 1B': [],
'BSF 4A': [],
'BSF 3': [],
'BSF 1A': [],
'BSF Orchard': [],
'TF 4': [],
'TF 3B': [],
'TF 3A': [],
'TF 5': [],
'TF 11': [],
'TF 8': [],
'TF 1': [],
'TF 2': [],
'WA 3': [],
'WA 7': [],
'WA 5B': [],
'WA 1': [],
'WA 5A': []},
等
我看到我可以通过遵循所需的路径来访问列表:crops[year]["field_name"]
,但是当我尝试使用crops[year]["field_name"].append('Corn')
追加到该列表时,程序会在该列表的后面附加“ Corn”字段名称,与年份无关。因此crops[2015]["Field 1"]
将有玉米,crops[2016]["Field 1"]
和crops[2017]["Field 1"]
也将有玉米,即使我只打算使用{{1 }}
我可能只是对如何导航数据结构感到困惑,但是任何帮助将不胜感激。
答案 0 :(得分:0)
它按预期工作就可以了
crop_dict = {
2015: {
'CP 4B1': [],
'CP 4D1': []
},
2016: {
'CP 4B1': [],
'CP 4D1': [],
}}
crop_dict[2015]["CP 4B1"].append('Corn')
print(crop_dict[2015]["CP 4B1"])
print(crop_dict[2016]["CP 4B1"])
输出:
['Corn']
[]
答案 1 :(得分:0)
您应该遵循以下语法向字典中添加/添加新值,有几种解决方法,尝试使用这两个选项(这是一个示例,为自己的问题实施它,希望对您有所帮助):
food_dict = {
'Sauce': {
'Tomato': [],
'Mayo': []
}
}
food_dict['Sauce']['Tomato'] = [5]
## or
for k in food_dict.keys():
if k == "Sauce":
food_dict[k]['Mayo'] = [100]
print(food_dict)
输出:
{'Sauce': {'Tomato': [5], 'Mayo': [100]}}