python 给出班里某门课程的成绩文件test5.csv(utf-8编码),每行为每个学生的名字和他的成绩, 中间用逗号隔开。请你按成绩从高到低对数据排序输出,如果有相同分数则名字字典序小的在前(按名字升序)排序。
时间: 2024-03-10 22:50:07 浏览: 65
成绩排序(python)
5星 · 资源好评率100%
好的,可以使用 Python 的 csv 和 sorted 模块来实现。下面是代码实现:
```python
import csv
with open("test5.csv", "r", encoding="utf-8") as f:
reader = csv.reader(f)
data = [row for row in reader]
data = sorted(data[1:], key=lambda x: (-int(x[1]), x[0]))
for row in data:
print(row[0], row[1])
```
首先,我们使用 csv 模块读取 csv 文件并将读取到的数据存储在列表 data 中。然后,我们使用 sorted 函数对 data 进行排序,排序的关键字是一个 lambda 函数,其中第一个关键字是成绩的负数(从高到低排序),第二个关键字是名字(按字典序升序排序)。最后,我们遍历排序后的 data 列表,将每个学生的名字和成绩输出即可。
阅读全文