我正在尝试将.txt文件中的值导入到字典中,代码如下所示:
def displayInventory():
Inventory = {}
_openfile = open('database.txt','r+',)
_readfile = _openfile.read()
_readfile = _readfile.replace('$'," ")
print _readfile
_splitline = _readfile.split("\n")
for line in _splitline:
_line = line.split()
Inventory[_line[0]+","+_line[1]] = _line[2:]
print Inventory
它设法将不同的值导入字典,但我面临的问题是这个。 文本文件中的某些值最终具有相同的键。添加到字典中的文本文件中的值将覆盖字典中键的当前值,如下所示。
Shakespeare William Romeo And Juliet 5 5.99
Shakespeare William Macbeth 3 7.99
Dickens Charles Hard Times 7 27.00
Austin Jane Sense And Sensibility 2 4.95
Dickens Charles David Copperfield 4 26.00
Austin Jane Emma 3 5.95
Hawthrone Nathaniel The Scarlet Letter 6 18.00
Shakespeare William Hamlet 10 6.99
Chaucer Geoffrey The Canterbury Tales 4 20.00
Dickens Charles Great Expectations 2 25.00
{'Hawthrone,Nathaniel': ['The', 'Scarlet', 'Letter', '6', '18.00'],
'Chaucer,Geoffrey': ['The', 'Canterbury', 'Tales', '4', '20.00'],
'Dickens,Charles': ['Great', 'Expectations', '2', '25.00'],
'Shakespeare,William': ['Hamlet', '10', '6.99'],
'Austin,Jane': ['Emma', '3', '5.95']}
如何在单个密钥中重写代码,例如莎士比亚,威廉将拥有他所写的书籍的所有价值。 对这个冗长的问题抱歉。 任何建议都非常感谢。
答案 0 :(得分:1)
只需更改dict即可存储列表并继续附加特定作者姓名的值。
for line in _splitline:
_line = line.split()
Inventory.setdefault(_line[0]+","+_line[1], [])
Inventory[_line[0]+","+_line[1]].append(_line[2:])
答案 1 :(得分:0)
您应该添加一个if子句以查看该键是否已存在,如果是这种情况,请增加字典中的值,而不是替换:
key = _line[0]+","+_line[1]
if key in Inventory:
Inventory[key] = += _line[2:]
else:
Inventory[key] = _line[2:]