
У меня есть файл в следующем формате -
root 0 system 0
bin 2
sys 3
security 7
cron 8
audit 10
lp 11
daemon 1 staff 1
bin 2 bin 2
sys 3
adm 4
sys 3 sys 3
И хочу преобразовать его в новый файл с форматом, используя скрипт оболочки -
root system,bin,sys,security,cron,audit,lp
daemon staff
bin bin,sys,adm
sys sys
решение1
Готовое awk
решение:
awk 'NF==4 && NR>1 {printf "\n" ; }
NF==4 { printf "%-10s %s",$1,$3}
NF==2 { printf ",%s",$1}
END { printf "\n" ; } '
где
NF
Номер поля (номер столбца),NR
Номер записи (номер строки),- различные условия выбирают, что печатать,
printf
не печатает завершающую новую строку.
решение2
perl -lane '
if ( @F == 4 ) { # num fields are 4
print $result if $. > 1; # in case we"re not @ BOF, show result
$result = join "\t", @F[0,2]; # initialize result
} else {
$result .= ",$F[0]"; # append result
}
eof && print $result; # on the last line, show result
' filename
решение3
perl -0pe 's/\h+\d+\h*\n\h+/,/g; s/\h+\d+//g' ex
- первая замена заменяет числа, за которыми
\n...spaces
следует,
- вторая замена удаляет остальные числа.