awk

awkのコマンド内でシェル変数を使う方法

アクセスログから特定のレスポンスステータスを抜き出す簡易的なスクリプトを作っていたのですが、awk の中でシェル変数を使う機会があったので備忘録として残しておきます。

今まで使う機会なかったのですが少しハマりました。

シングルクォートの使い方がポイント

結果としては、awk はシングルクォートに囲まれたところを解析しようとするので、シェル変数の部分はシングルクォートから外してあげればシェル変数として扱ってくれるということです。

awk 内でステータスコードの値を持ったシェル変数をそのまま定義すると、下記の通り解釈できずに syntax error が出ます。

よって、下記のように awk コマンド内の ${s} のシェル変数をシングルクォートで囲んであげます。