1

我有两个文件,

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循环,但出现错误,有人可以帮忙吗?谢谢!

4

2 回答 2

5

如果您真的想同时读取两个文件(这似乎不是您的实际问题——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
于 2013-03-26T18:24:41.900 回答
2

使用join命令将 A 和 B 合并到一个文件 C 中:

$ join A.txt B.txt
john 1 2 3 4 5 6 7 7.5
Ely 10 9 9 9 9 9 9 4.5
Maria 3 5 7 9 2 1 4 3,7
Rox 10 10 10 10 10 10 10 8.5

修改当前脚本以处理此表单中的数据应该很简单。

于 2013-03-26T18:22:10.793 回答