
Tengo un archivo en el siguiente formato:
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
Y quiero convertirlo en un archivo nuevo con formato usando un script de Shell:
root system,bin,sys,security,cron,audit,lp
daemon staff
bin bin,sys,adm
sys sys
Respuesta1
Una solución lista para awk
usar:
awk 'NF==4 && NR>1 {printf "\n" ; }
NF==4 { printf "%-10s %s",$1,$3}
NF==2 { printf ",%s",$1}
END { printf "\n" ; } '
dónde
NF
es el número de campo (número de columna),NR
es Número de registro (número de línea),- varias condiciones seleccionan qué imprimir,
printf
no imprime la nueva línea final.
Respuesta2
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
Respuesta3
perl -0pe 's/\h+\d+\h*\n\h+/,/g; s/\h+\d+//g' ex
- la primera sustitución reemplaza los números seguidos
\n...spaces
de,
- La segunda sustitución elimina los otros números.