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



カテゴリー

今週よく読まれている記事

  1. 学会・会議で英語が絶望的にできなくて困るケース | オンライン開催で「英語力のなさ」を痛感した場合の対処法

    学会・会議で英語ができなくてに困るケース学会やイベント・会議などが、オンラインで開催される…
  2. r tidyverse 使い方 | 列 filter 絞り込み select関数 – dplyrパッケージ

    tidyverseで1つのデータフレームの列の絞り込みは、dplyrパッケージのselect関数を…
  3. プログラミングで疲れた脳をリフレッシュ 〜 鬼滅の刃「感動」と「やる気アップ」でストレス発散!

    ストレス発散は鬼滅で。「50%OFF」で読む!脳のパフォーマンスを上げるには、適度な休憩と…
  4. AWS ディスク容量不足 新しいボリュームを追加する

    バイオインフォマティクスでは大きなファイルを扱うことがあるので、ディスク不足に陥ることがあります。…
  5. 「知っている」と「知らない」とでは、もしものとき、大違いになる – コロナうつ対策

    コロナうつなどという言葉を聞くようになりましたが、派遣切り、解雇、リストラは、これから本格化します…

人気記事

  1. IGV, 解析ツール

    IGV 使い方 インストール〜便利な使い方まで | リファレンス・マッピングデータ・アノテーションを読み込んで表示しよう
    IGV(Integrative Genomics View…
  2. R言語

    R subset関数 データフレームやmatrixからの条件指定による行・列の抽出
    R の subset関数は、データフレームやマトリックスか…
  3. Excel, 統計

    z-score 計算方法 エクセル(Excel) 編
    統計処理で、大きく変化しているなどの判断基準にも使われる値…

おすすめ記事

  1. シェルスクリプト

    シェルスクリプト | ファイル存在チェック・空ファイルチェック
    bashでスクリプトを作成するときに、よく使うのがファイル…
  2. R言語, グラフ

    R 使い方 軸・ラベルの調整(向き・サイズ・色など) グラフの描き方
    Rによるplot(グラフ)の描画は、手軽で大変便利です。た…
  3. awk, シェルスクリプト

    bash 部分文字列・置換・長さ・連結・分割の文字列処理
    bashのよく使う文字列処理、部分文字列・置換・連結・長さ…