次のような入力ファイルがあります。
line 1
line 2
line 3
line 4
line 5
line 6
awk を使用して、数行ごとに空白行を挿入したいと思います。たとえば、2 回ごとに次のように指定します。
line 1
line 2
line 3
line 4
line 5
line 6
awk で n 行ごとに空白行をファイルに入れるにはどうすればよいですか?
次のような入力ファイルがあります。
line 1
line 2
line 3
line 4
line 5
line 6
awk を使用して、数行ごとに空白行を挿入したいと思います。たとえば、2 回ごとに次のように指定します。
line 1
line 2
line 3
line 4
line 5
line 6
awk で n 行ごとに空白行をファイルに入れるにはどうすればよいですか?
smcameronの答えを書くためのより「ぎこちない」方法:
awk -v n=5 '1; NR % n == 0 {print ""}'
「1;」常に真である条件であり、現在の行を印刷するデフォルトのアクションをトリガーします。
awk '{ if ((NR % 5) == 0) printf("\n"); print; }'
n == 5
もちろん、のために。あなたの考えが何であれ代用してくださいn
。
もっとぎこちない:
awk 'ORS=NR%5?RS:RS RS'
例えば:
$ printf "%s\n" {1..12} | awk 'ORS=NR%5?RS:RS RS'
1
2
3
4
5
6
7
8
9
10
11
12
awk '{print; if (FNR % 5 == 0 ) printf "\n";}' your_file
「print」は「printf」の前にある必要があると思います.FNRはあなたのタスクに対してより正確です。
$ awk -v n=5 '$0=(!(NR%n))?"\n"$0:$0'
n を変更したい場合は、awk の -v オプションでパラメータ n を設定してください。