awk while・do 繰り返し処理

スポンサーリンク

awkの繰り返し処理(forwhiledo)についてまとめます。今回は、whiledoについて。

とにかく早く問題解決したい人はこちら>>直接、データ解析相談

awk while 繰り返し処理

条件を満たせば「ずっと」繰り返しを行います。繰り返し処理の最初で毎回条件をチェックします。条件を満たせば処理を繰り返します。また、繰り返し処理の中にbreakを書いて強制的に繰り返しを終了させることもできます。

awk while 繰り返し処理 書き方

書式

先頭に条件式を書きます。そのブロック内に繰り返しの処理を書きます。

while (条件) {
    処理
}

awk while 繰り返し処理 使い方

まずwhileの条件式がチェックされます。「真」ならブロック処理実行、「偽」なら実行されません。実行された場合、繰り返すたびに状態が少しずつ変化し、そのうち条件を満たさなくなってwhile処理を抜けるというような使い方をします。

簡単な使い方

データファイル(awk_while1.dat)の1行毎の各フィールドを先頭から3つずつ表示して改行します。コメント行以外の全てに対して行います。

$ cat awk_while1.dat
# comment
1a 1b 1c 1d 1e
2a 2b 2c 2d 2e
3a 3b 3c 3d 3e
awk_while1.awk
!/^#/{
    i=1
    while (i<=3) {
	printf("%s ", $i)
	i++
    }
    printf("\n")
}
$ awk -f awk_while1.awk awk_while1.dat 
1a 1b 1c
2a 2b 2c
3a 3b 3c

簡単な使い方 – breakを使った制御

データファイルの1行毎の各フィールドを先頭から3つずつ表示して改行します。breakでループを制御します。

awk_while2.awk
!/^#/{
    i=1
    while (1) { # while(1)は永遠に繰り返すの意味
	if (i>3) break;  # 必ずbreakを準備する
	printf("%s ", $i)
	i++
    }
    printf("\n")
}
#スクリプトが暴走したら、慌てず「Ctrl」を押したまま、「C」を押します。 
$ awk -f awk_while2.awk awk_while1.dat 
1a 1b 1c
2a 2b 2c
3a 3b 3c

awk do 繰り返し処理

whileとほとんど同じです。大きな違いは、最初に条件チェックするか(while)・最後に条件チェックするか(do)です。doは最初に条件をチェックしません。条件によらず少なくとも1回は実行する繰り返し処理につかうと便利です。doも、条件を満たせば「ずっと」繰り返しを行う点は同じです。また、while同様、繰り返し処理の中にbreakを書いて強制的に繰り返しを終了させることもできます。

awk do 繰り返し処理 書き方

書式

最後に条件式を書きます。そのブロック内に繰り返しの処理を書きます。

do {
    処理
} while(条件)

awk do 繰り返し処理 使い方

まず最初に1回、ブロック処理を実行します。そのあとの条件チェックで「真」なら繰り返し、「偽」なら実行されません。実行された場合、繰り返すたびに状態が少しずつ変化し、そのうち条件を満たさなくなってdo処理を抜けるというような使い方をします。

簡単な使い方

データファイル(awk_do1.dat:awk_while1.datと同じ)の1行毎の各フィールドを先頭から1つずつ表示して改行します。1列目だけは条件によらず表示します。whileの条件を他の列が存在すれば…など工夫して使うと良いと思います。

$ cat awk_do1.dat
# comment
1a 1b 1c 1d 1e
2a 2b 2c 2d 2e
3a 3b 3c 3d 3e
awk_do1.awk
!/^#/{
    i=1
    do {
	printf("%s ", $i)
    } while(!i) # 条件を否定しています
    printf("\n")
}
$ awk -f awk_do1.awk awk_do1.dat 
1a
2a
3a
とにかく早く問題解決したい人はこちら>>直接、論文相談

関連記事

awk 行の表示 先頭行 最終行 指定行
awkは、テキスト処理に欠かせません。よく使う「行を指定した処理」に使える定型スクリプトをまとめました。簡単に書けるように、省略できる部分は極力省きました。 awk と 行 awkで行を指定して「何かの処理」を実行するときは、「いま何行目?...
awk 置換や部分文字列などの文字列処理 gsub sub match index split 等
awkの文字列関数について、置換や部分文字列処理など、よく使う代表的なものを簡単なサンプルを使って紹介します。 awk 置換 文字列置換 gsub sub gsub・subは、対象となる文字列tについて正規表現rにマッチした部分を置換文字列...
awk 複数行の処理
ファイルには様々な形式があります。1行単位で記述されたCSV(カンマ区切り)ファイルやTSV(タブ区切り)ファイルは、awkやsed、その他のbashコマンドなどを使っても比較的処理がしやすい。しかし、複数行でレコードが構成される場合(1行...
awk split | サンプルでわかる列の分割とセパレータ指定方法
awkのsplit関数は、セパレータを指定して文字列を分割することができます。セパレータには文字や正規表現で指定できて、指定しない場合はフィールドセパレータがデリミタとして使われます。分割後の単語は、配列に格納されて1〜分割数nまでのインデ
404 NOT FOUND | バイオインフォ 道場 [bioinfo-Dojo]
バイオインフォ 道場
404 NOT FOUND | バイオインフォ 道場 [bioinfo-Dojo]
バイオインフォ 道場
awk 配列 使い方
awkでは、他のプログラミング言語のように配列を使うことができます。配列の簡単な使い方のまとめです。 とにかく早く問題解決したい人はこちら>>直接、データ解析相談 awk 連想配列 awkの配列では、インデックスには文字列でも数字でも使うこ...
awk よく使うシステム変数と使い方
awkのスクリプトでは、参照や設定が可能な「特殊な変数(システム変数)」を使うことができます。 とにかく早く問題解決したい人はこちら>>直接、データ解析相談 よく使うシステム変数 awkのスクリプトでシステム変数を使うと、より簡潔にスクリプ...
awk パターンとアクション
awkは、入力行に対してフィルタリングなどの処理を行う際によく用いられます。入力行に対して「どの行に処理を行うか」を指定するのがパターン、「どんな処理を行うか」を指定するのが「アクション」です。 とにかく早く問題解決したい人はこちら>>直接...
awk 区切り文字とフィールド
awkは、入力の各行を区切り文字でフィールドに分割して、それぞれを個別に取り出すことができます。 とにかく早く問題解決したい人はこちら>>直接、データ解析相談 awk 区切り文字の変更 入力行をフィールドに分割するのは区切り文字です。デフォ...
awk コマンドラインでの実行とスクリプトファイルでの実行
awkを実行する場合、コマンドラインで指定する方法と、スクリプトファイルを指定する方法があります。 とにかく早く問題解決したい人はこちら>>直接、データ解析相談 awk コマンドラインで指定する patternとactionは、シングルクォ...
awk 使い方 フィールド取り出し スクリプトの書き方
awkで簡単なフィールドデータの取り出しを行います。awk は入力された行について、空白やタブで区切られたデータをフィールドと解釈します。・…を指定することで、各行のフィールドを取り出すことができます。尚、https://bioinfo-dojo.net/2016/02/18/awk_easy_field_filter/は入力行全体です。se...
正規表現 メタキャラクタ 検索・置換 前編
sed や awk、grep、その他のプログラム処理で文字列を扱うときに、よく用いられる「正規表現」についてまとめます。 とにかく早く問題解決したい人はこちら>>直接、データ解析相談 正規表現とは 正規表現とは、文字列集合を特殊文字(メタキ...
正規表現 メタキャラクタ 検索・置換 後編
sed や awk、grep、その他のプログラム処理で文字列を扱うときに、よく用いられる「正規表現」についてまとめます。 とにかく早く問題解決したい人はこちら>>直接、データ解析相談 正規表現とは 正規表現とは、文字列集合を特殊文字(メタキ...

コメント

  1. […] while・do 繰り返し処理 – バイオインフォ 道場 […]

タイトルとURLをコピーしました