Я хотел бы изменить:
e·ver·y·bo·dy
к:
e·ver·y·bo·dy
e·ver·y·bo·
e·ver·y·
e·ver·
e·
Петля for
будет гораздо предпочтительнее.
решение1
Здесь также используется for
цикл, хотя и awk- for
цикл:
$ 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·
e·
Альтернативная версия от короткой к длинной
$ 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·
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·
e·ver·
e·ver·y·
e·ver·y·bo·
e·ver·y·bo·dy
решение2
Вы можете сделать это корочеawkкоманду, как показано ниже (длинный к маленькому):
$ 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·
e·
И изот маленького до длинногоследующим образом:
$ awk -F'·' '{i=1; while(i<NF){ print tmp=tmp$((i++))"·"} print $0}' file
e·
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
Сначала нам нужно установитьвнутренний разделитель файловto ·
. Затем цикл for проходит по каждому куску и печатает его, но в неправильном порядке. Вот почему tac
в конце меняет порядок на противоположный.
Выдает мне результат:
e·ver·y·bo·dy·
e·ver·y·bo·
e·ver·y·
e·ver·
e·
решение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
получаем желаемый вывод.