我将如何获取文件的内容并将其更改为字典?内容将包括这种形式的菜单项:
1 Chocolate ice cream
2 Green tea
8 Shrimp roll
我希望关键是数字,价值是食物。
到目前为止,我得到了:
d = {}
for line in menu.read().strip().split():
d[line[0]] = d[line[1:]]
return d
但这出来歪了...
我将如何获取文件的内容并将其更改为字典?内容将包括这种形式的菜单项:
1 Chocolate ice cream
2 Green tea
8 Shrimp roll
我希望关键是数字,价值是食物。
到目前为止,我得到了:
d = {}
for line in menu.read().strip().split():
d[line[0]] = d[line[1:]]
return d
但这出来歪了...
逐行循环文件对象,然后拆分行:
with open('inputfilename.txt') as menu:
d = {}
for line in menu:
key, value = line.split(None, 1)
d[key] = value.strip()
return d
该.split(None, 1)
调用应用默认拆分算法(在任意宽度的空白处拆分),但将其限制为仅一次拆分以仅返回 2 个项目。优点是以空格开头的行(例如' 8 Shrimp roll'
您帖子中的行)也可以正确处理,因为在拆分之前会删除前导空格。
这会产生:
{'2': 'Green tea', '1': 'Chocolate ice cream', '8': 'Shrimp roll'}
你可以试试这个:
d = {}
for line in menu.read().strip().split():
d[line[0]] = line[1:] # you want to use just line[1:], than d[line[1:]]
return d
这里的问题是d[line[1:]]
为您提供了 key 映射的值line[1:]
。
>>> finalDict = {}
>>> with open('fileName.txt', 'r') as f:
for line in f:
key, elem = line.strip().split(" ", 1)
finalDict[int(key)] = elem
>>> finalDict
{8: 'Shrimp roll', 1: 'Chocolate ice cream', 2: 'Green tea'}
我们遍历文件的每一行,剥离它,然后在第一个空格处分割它。
字典理解怎么样?
{ k:v.strip() for k, v in (line.split(None, 1) for line in menu) }