我想按照他们的分数对名单进行排序。 到目前为止我所拥有的是
file = open("scores.txt", 'r')
for line in file:
name = line.strip()
print(name)
file.close()
我不确定如何对它们进行排序。
这是文件内容:
Matthew, 13
Luke, 6
John, 3
Bobba, 4
我想要的输出是什么:
John 3
Bobba 4
Luke 6
Matthew 13
有人可以帮忙吗?
答案 0 :(得分:5)
您可以使用.split(',')
方法将一行拆分为单独的部分,然后使用int()
将得分转换为数字。 .sort()
方法对列表进行了排序,key
告诉它要排序的内容。
scores = []
with open("scores.txt") as f:
for line in f:
name, score = line.split(',')
score = int(score)
scores.append((name, score))
scores.sort(key=lambda s: s[1])
for name, score in scores:
print(name, score)
这将为您提供按排序顺序包含(名称,分数)对的元组列表。如果您想在它们之间用逗号打印出来(为了保持一致),请将打印更改为print(name, score, sep=', ')
输入文件的读取也可以表示为一(大)行
with open("scores.txt") as f:
scores = [(name, int(score)) for name, score in (line.split(',') for line in f)]
key=
的简要说明:
lambda函数是一个匿名函数,即没有名称的函数。当您只需要一个小型操作的功能时,通常会使用这些。 .sort
有一个可选的key
关键字参数,它接受一个函数并使用该函数的返回来对对象进行排序。
所以这个lambda
也可以写成
def ret_score(pair):
return pair[1]
然后你可以编写.sort(key=ret_score)
但是因为我们不需要其他任何功能,所以没有必要声明它。 lambda语法是
lambda <arguments> : <return value>
所以这个lambda接受一对,并返回其中的第二个元素。如果您愿意,可以保存lambda
并像常规功能一样使用它。
>>> square = lambda x: x**2 # takes x, returns x squared
>>> square(3)
9
>>> square(6)
36