2016-06-15 3 views
1

これは基本的なプログラムですが、私は初心者なので解決策を理解することはできません。私はすべての147のために一つのファイルall_1.datで「ASN-2」というように含むすべての行を抽出する必要がありtcshエラー:whileループ

-75.635 105.879 ASN-2 
-153.704 64.7089 ARG-3 
-148.238 -47.6076 GLN-4 
-63.2568 -8.05441 LEU-5 
-97.8149 -7.34302 GLU-6 
-119.276 8.99017 ARG-7 
-144.198 -103.917 SER-8 
-65.4354 -10.3962 GLY-9 
-60.6926 12.424 ARG-10 
-159.797 -0.551989 PHE-11 
65.9924 -48.8993 GLY-12 
179.677 -7.93138 GLY-13 
.......... 
........... 
-70.5046 38.0408 GLY-146 
-155.876 153.746 TRP-147 
-132.355 151.023 GLY-148 
-66.2679 167.798 ASN-2 
-151.342 -33.0647 ARG-3 
-146.483 41.3483 GLN-4 
.......... 
.......... 
-108.566 0.0212432 SER-139 
47.6854 33.6991 MET-140 
47.9466 40.1073 ASP-141 
46.4783 48.5301 SER-142 
-139.17 172.486 LYS-143 
    58.9514 32.0602 SER-144 
    60.744 18.3059 SER-145 
-94.0533 165.745 GLY-146 
-161.809 177.435 TRP-147 
129.172 -101.736 GLY-148 

私は、次の形式でrama.xvgという名前のファイルを持っています残渣。私は、ターミナルで次のコマンドを実行した場合

、それはASN-2のための所望の出力できます:全ての残基のためにそれを繰り返し行うことを避けるために

awk '{if(NR%147 == 1) printf $0 "\n"}' rama.xvg > all_1.dat 

を、私は次のコードを書かれています。

#!/bin/tcsh 
set i = 1 
    while ($i < 148) 
    echo $i 
    awk '{if(NR%147 == i) printf $0 "\n"}' rama.xvg > all_"$i".dat 
    @ i++ 

end 

しかし、このコードは、すべての出力ファイルにGLY-148を含む行を出力します。

このコードのエラーは何か教えてください。私はそれが入れ子に関連していると思います。

答えて

2

awk -lineの変数iは、シェル変数ではないawk変数です。あなたが行うことができますシェル変数$iを使用したい場合:

awk -v i="$i" '{if(NR%147 == i) printf $0 "\n"}' rama.xvg > all_"$i".dat 

しかし、私はより良いawkにあなたのwhile -loopを置くと思います:

awk '{for (i=1; i<=147; i++) { if (NR%147==i) {printf $0 "\n" > ("all_" i ".dat") } } }' rama.xvg 
+0

それは動作します。ありがとうございました。 –

+0

あなたは大歓迎です:) – uzsolt