我有两个文件,
A
john 1 2 3 4 5 6 7
Ely 10 9 9 9 9 9 9
Maria 3 5 7 9 2 1 4
Rox 10 10 10 10 10 10 10
B
john 7.5
Ely 4.5
Maria 3,7
Rox 8.5
我想要做的是创建另一个文件,其中仅包含文件 A 中的平均值大于或等于 8.5 且 B 中的分数也大于或等于 8.5 的人员,因此在我的示例中,C 文件将仅包含 Rox,因为只有她符合标准。
我有这个
#shell program
echo "Fiserul are numele $1"
filename=$1
filename2=$2
echo "">temp.txt
touch results
compara="8.5"
cat $filename | while read -r line
do
nota=0
media=0
echo " $line"
rem=$( echo "$line"| cut -f 2- -d ' ')
for word in $rem
do
echo "$word"
nota=$(($nota+$word))
echo "Nota=$nota"
done
media=$(($nota / 7))
if [ "$(echo $media '>=' $compara | bc -l)" -eq 1 ];
then
nume=$( echo "$line"| cut -f 1 -d ' ')
echo "$nume $media" >> temp.txt
fi
echo "Media : $media"
done
cat $filename2 | while read -r line
do
所以我在 temp.txt 文件中有满足文件 A 标准的人,但我的问题是如何将他们与 filename2 中的人进行比较并从中创建“结果”?
我尝试过两个 while 循环,但出现错误,有人可以帮忙吗?
谢谢!
If you really想要同时读取两个文件(这似乎不是您的实际问题 -join
确实是适合您正在做的事情的正确工具),您可以在不同的 FD 上打开它们:
while IFS= read -r -u 4 line1 && IFS= read -r -u 5 line2; do
echo "Line from first file: $line1"
echo "Line from second file: $line2"
done 4<file1 5<file2
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)