用Linux实现:求出内容如下的 ScoreSheet.txt 文件中各科成绩的最低分、最高分与
平均分,并给出最低分和最高分获得者的姓名。
No Name Chinese English Computer Math
1 LiuYi 75 95 80 90
2 ChenEr 80 75 85 95
3 ZhangSan 90 80 95 85
4 LiSi 95 95 75 90
5 WangWu 70 80 95 90
6 ZhaoLiu 95 80 75 90
你可以使用Linux命令来实现求出各科成绩的最低分、最高分和平均分,并找出最低分和最高分获得者的姓名。
首先,打开终端并进入文件所在的目录,然后执行以下命令:
```
cat ScoreSheet.txt | awk 'NR>1 {print $0}' | awk '{print $3,$4,$5,$6}' > scores.txt
```
这个命令会将除了第一行以外的所有行提取出来,并将每个学生的中文、英语、计算机和数学成绩保存到一个新的文件scores.txt中。
接下来,我们可以使用以下命令来计算最低分、最高分和平均分:
```
echo "Chinese" && awk '{print $1}' scores.txt | sort -n | head -n 1 && echo "English" && awk '{print $2}' scores.txt | sort -n | head -n 1 && echo "Computer" && awk '{print $3}' scores.txt | sort -n | head -n 1 && echo "Math" && awk '{print $4}' scores.txt | sort -n | head -n 1
```
这个命令会依次输出中文、英语、计算机和数学成绩的最低分。
然后,我们可以使用以下命令来计算最高分和最低分获得者的姓名:
```
echo "Chinese" && awk '{print $2" "$1}' scores.txt | sort -k 2 -n | tail -n 1 && echo "English" && awk '{print $3" "$1}' scores.txt | sort -k 2 -n | tail -n 1 && echo "Computer" && awk '{print $4" "$1}' scores.txt | sort -k 2 -n | tail -n 1 && echo "Math" && awk '{print $5" "$1}' scores.txt | sort -k 2 -n | tail -n 1
```
这个命令会依次输出中文、英语、计算机和数学成绩的最高分获得者的姓名。
执行以上命令后,你将得到所需的结果。