【发布时间】:2014-02-12 02:02:39
【问题描述】:
我目前正在尝试将值插入到列表中,该列表通过首先识别匹配项被打包到字典中。如果我有这样的字典:
{'12633': ['11-Mar-11', '26-Apr-11'], '11359': [], '11458': ['6-Aug-10'], '16335': ['29-May-13'], '11101': []}
我目前正在尝试做的是逐行读取文件并确定密钥是否存在于我的字典中。然后确定该值是否匹配或存在于字典键返回的列表中。此时,我想从列表中匹配值旁边的行中插入一个值。
with open('Pfa.csv', 'r') as f:
for line in f:
#split the line up into individual element - it's a csv file
line = line.strip('/n')
splitline = line.split(',')
#check if the value in the file exists as a key in the dictionary
if splitline[0] in Ndates:
#iterate over the list in the dictionary
for item in Ndates[splitline[0]]:
#check if the item within the dictionary list is within this line in the file
if item == splitline[1]:
#insert a vale from the file next to the value in the list within the dictionary
Ndates[splitline[0]].insert(Ndates[splitline[0]].index(item), splitline[4].strip('\n'))
不幸的是,由于某种我无法识别的原因,它似乎卡在循环数据上。只需将值附加到列表中就可以了,但是它很乱并且有将近 3k 个值,我不想手动完成。
非常感谢任何帮助让我知道我哪里出错了。我觉得我这样做效率很低,但我愿意学习。
【问题讨论】:
标签: python loops dictionary insert indexing