python 问题描述】 给出班里某门课程的成绩文件test5.csv(utf-8编码),每行为每个学生的名字和他的成绩, 中间用逗号隔开。请你按成绩从高到低对数据排序输出,如果有相同分数则名字字典序小的在前(按名字升序)排序。 【输入形式】 输入来自文件 【输出形式】 把成绩按分数从高到低的顺序进行排序并输出,每行包含名字和分数两项,之间有一个空格。 【样例输入】 文件内容如下时: Kitty,80 Tom,28 Hanmeimei,90 Joey,92 Tim,28 【样例输出】 Joey 92 Hanmeimei 90 Kitty 80 Tim 28 Tom 28 下列代码哪里出错了?with open('text5.csv','rt')as f: s=f.readlines() s.sort(key=lambda x:(-x[1],x[0])) print(s)
时间: 2024-03-23 20:40:56 浏览: 93
成绩排序(python)
5星 · 资源好评率100%
代码中有两个问题:
1. 文件名应该是 `test5.csv`,而不是 `text5.csv`,因此应该修改为 `with open('test5.csv','rt') as f:`。
2. `f.readlines()` 会读取整个文件的内容并返回一个字符串列表,每个字符串对应文件中的一行。因此,排序时应该先将每一行拆分为名字和成绩两个元素,并将成绩转换为整数类型。修改后的代码如下:
```python
with open('test5.csv', 'rt', encoding='utf-8') as f:
s = [line.strip().split(',') for line in f]
s.sort(key=lambda x: (-int(x[1]), x[0]))
print(s)
```
这个代码会按照要求对成绩进行排序,并将排序后的结果打印出来。
阅读全文