出力を区切り文字で分割するにはどうすればいいでしょうか?

出力を区切り文字で分割するにはどうすればいいでしょうか?

変更したい点:

e·ver·y·bo·dy

に:

e·ver·y·bo·dy
e·ver·y·bo·
e·ver·y·
e·ver·

ループforが大いに好まれます。

答え1

これもforループを使用しますが、awkforループです。

$ echo "e·ver·y·bo·dy" | awk -F· -v OFS=· '{print;for (i=NF;i>1;i--){$i="";print;NF--} }'
e·ver·y·bo·dy
e·ver·y·bo·
e·ver·y·
e·ver·

短いバージョンから長いバージョンへの代替バージョン

$ echo 'e·ver·y·bo·dy' | awk -F· -v OFS=· '{for (i=1;i<=NF;i++){for (j=1;j<=i;j++)printf "%s%s",$j,j<NF?OFS:"";print""} }'
e·ver·
e·ver·y·
e·ver·y·bo·
e·ver·y·bo·dy

別のバリエーション

$ echo 'e·ver·y·bo·dy' | awk -F· -v OFS=· '{s="";for (i=1;i<=NF;i++){s=s OFS $i; printf "%s",substr(s,2); print (i==NF)?"":OFS} }'
e·ver·
e·ver·y·
e·ver·y·bo·
e·ver·y·bo·dy

答え2

もっと短くすることもできます以下のようにコマンドを実行します(長いから小さい):

$ awk -F'·' '{while (NF){ print $0;NF--;ORS="·\n"}}' OFS='·' file
e·ver·y·bo·dy
e·ver·y·bo·
e·ver·y·
e·ver·

そして小さいものから長いものまで次のように:

$ awk -F'·' '{i=1; while(i<NF){ print tmp=tmp$((i++))"·"} print $0}' file
e·ver·
e·ver·y·
e·ver·y·bo·
e·ver·y·bo·dy

答え3

ループする必要がある場合for:

IFS=·
for l in $(echo "e·ver·y·bo·dy"); do x="$x$l·"; echo "$x"; done | tac

まず、内部ファイルセパレータ·。次に、 for ループが各ピースを実行し、それを間違った順序で出力します。tac最後に順序を逆にするのはそのためです。

出力は次のようになります:

e·ver·y·bo·dy·
e·ver·y·bo·
e·ver·y·
e·ver·

答え4

解決策は次のとおりですpython:

#!/usr/bin/env python2
# -*- coding: utf-8 -*-
input_str = 'e·ver·y·bo·dy'
input_list = input_str.split('·')
print input_str
i = len(input_list)
while i > 1:
    print '·'.join(input_list[:i-1]) + '·'
    i -= 1

ここでは、まずsplit入力文字列を·区切り文字として使用してリストを生成し、次にリストのスライスを使用してjoin目的の出力を取得します。

関連情報