The AWK Programming Languageから awk を学んでいますが、サンプルの 1 つに問題があります。
$2 が値 (たとえば ) と等しい場合に $3 を出力したい場合、次の1
コマンドを使用していましたが、これは正常に機能します。
awk '$2==1 {print $3}' <infile> | more
しかし、1 を別の検索条件 (例: findtext
) に置き換えると、コマンドが機能しません。
awk '$1== findtext {print $3}' <infile> | more
出力は返されず、入力ファイルに「findtext」が存在することは確かです。
私もこれを試しましたが、うまくいきません:
awk '$1== "findtext" {print $3}' <infile> | more
'test' という名前の私のテスト ファイルは次のとおりで、スペースで区切られた 9 つの行と 8 つのフィールドがあります。
1 11 0.959660297 0 0.021231423 -0.0073 -0.0031 MhZisp
2 14 0.180467091 0.800424628 0 0.0566 0.0103 ClNonZ
3 19 0.98089172 0 0 -0.0158 0.0124 MhNonZ
4 15 0.704883227 0.265392781 0.010615711 -0.0087 -0.0092 MhZisp
5 22 0.010615711 0.959660297 0.010615711 0.0476 0.0061 ClNonZ
6 23 0.715498938 0 0.265392781 -0.0013 -0.0309 Unkn
7 26 0.927813163 0 0.053078556 -0.0051 -0.0636 MhZisp
8 44 0.55626327 0.222929936 0.201698514 0.0053 -0.0438 MhZisp
9 31 0.492569002 0.350318471 0.138004246 0.0485 0.0088 ClNonZ
これが私がしたことと出力です:
$awk '$8 == "ClNonZ" {print $3}' test
$ grep ClNonZ test
2 14 0.180467091 0.800424628 0 0.0566 0.0103 ClNonZ
5 22 0.010615711 0.959660297 0.010615711 0.0476 0.0061 ClNonZ
9 31 0.492569002 0.350318471 0.138004246 0.0485 0.0088 ClNonZ
これは、$8 に「ClNonZ」が含まれる $3 であると予想されます。
0.180467091
0.010615711
0.492569002
awk コマンドが何も返さなかった理由がわかりません。何かご意見は?