我正在做这个项目来从包含“员工姓名”和“每月销售数据”的外部 .txt 文件中提取数据。文本文件的格式(完整文件:是 'string' 后跟 12 个浮点实例)
last name, first name
45
23
34
....
last name2, first name2
78
32
23
....
我的程序几乎完成了,但我需要在打印结果时将“姓氏,名字”格式化为“名字,姓氏”。这是该部分的代码,因此您可以获得更好的主意。我正在使用 'dict()' 和 .iteritems() 来查看原始文件中的 7 名员工及其各自 12 个月的销售额:
data = {} # dict: list of all values for person by person name
with open("SalesData.txt", "rt") as f:
data_key = f.readline() # We remember first line (first man)
data[data_key] = [] # empty list of values
for line in f:
# then we suppose every line is float.
try:
# convert to float
value = float(line.strip())
# add to data
data[data_key].append(value)
# If it does not convert, then it is next person
except ValueError:
# next person's name
data_key = line
# new list
data[data_key] = []
for employee, stats in data.iteritems():
print employee
请注意,“员工”存储为“姓氏,名字”,我只想切换它并去掉“,”。
任何帮助将不胜感激!我刚开始使用 dict(),有时我发现很难操作数据。
更新 主要问题不是实际的格式。这就是发生的事情:我曾经在收集数据后,格式化“姓氏,名字”
print ' '.join(employee.split(',')[::-1]).strip()
这项工作,但结果完全以这种方式打印:
Shelly (first name)
Adams (last name -also notice the blank space before Adams)