人力検索はてな
モバイル版を表示しています。PC版はこちら
i-mobile

UNIXのawkの使い方についてです。

あるデータファイルがあり、その中のコメント行は">"で始まりスペースが続いています。
このファイルをawkで処理して新しいファイルを作りたいと思っています。

新しいファイルには、データファイルのコメント行はそのまま残し、データ行についてはある数値の列が条件を満たしていれば特定の列を取り出す、という操作をしたいと思っています。
例: $3<20 {print $1,$2>"newfile"}

どのように記述したらよいか教えていただけますか。

●質問者: spin6536
●カテゴリ:コンピュータ インターネット
✍キーワード:AWK UNIX コメント データ ファイル
○ 状態 :終了
└ 回答数 : 1/1件

▽最新の回答へ

1 ● a-kuma3
●100ポイント ベストアンサー

とりあえず、標準出力を宛先にすると、↓のような感じ。

/^> */ {
 print;
 next;
}

$3 < 20 {
 print $1, $2
}

コメントの解釈については、">" で始まり、その後に空白がゼロ個以上続いて、更に任意の文字がある行だ、と意訳しました。

">" で始まり、その後に必ずスペースがあり、他の文字は無い、ということであれば、

/^> *$/ { ...

という感じでしょうか


で、実行するときには、上記のスクリプトファイルを、hoge.awk としたら、

% awk -f hoge.awk in.data > out.data

で、期待した回答になってます?

◎質問者からの返答

回答ありがとうございます。一行で済ませるにはどうしたらいいでしょうか。こんな感じで。(だめだった例ですが)→

awk '$1 = ">" {print $0>"out.data"} $3 < 20 {print $1,$2>"out.data"}' in.data

関連質問


●質問をもっと探す●



0.人力検索はてなトップ
8.このページを友達に紹介
9.このページの先頭へ
対応機種一覧
お問い合わせ
ヘルプ/お知らせ
ログイン
無料ユーザー登録
はてなトップ