从与源文件相同路径下的grade.in文件中读取数据,该数据为若干学生的学号和成绩,将成绩在80分段(大于等于80而小于90)的学生的学号和相应的成绩以相同的格式打印到与源程序相同路径的grade.out文件中。
时间: 2024-02-22 16:59:44 浏览: 27
好的,这是一个关于文件读写和字符串处理的问题。下面是实现的 Python 代码:
```python
# 打开输入和输出文件
with open("grade.in", "r") as f_in, open("grade.out", "w") as f_out:
for line in f_in:
# 读取每一行数据并分割出学号和成绩
sid, score = line.strip().split()
score = int(score)
# 判断成绩是否在80到90分之间,如果是则输出到输出文件中
if 80 <= score < 90:
f_out.write(f"{sid} {score}\n")
```
这段代码首先使用 `with open()` 语句打开输入文件 `grade.in` 和输出文件 `grade.out`,并且使用 `r` 和 `w` 模式分别表示读和写。然后使用 `for` 循环遍历每一行数据,使用 `strip()` 方法去除每一行两端的空白字符,并使用 `split()` 方法分割出学号和成绩。注意,这里的 `split()` 方法默认以空格作为分隔符。
接着,将成绩从字符串类型转换为整数类型,并使用 `if` 语句判断成绩是否在80到90分之间。如果是,则使用 `f_out.write()` 方法将学号和成绩格式化后输出到输出文件中。注意,这里的 `f_out.write()` 方法使用 `f-string` 格式化字符串,可以方便地插入变量。
最后,使用 `with` 语句自动关闭输入和输出文件,避免资源泄漏。
相关推荐
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)