Classificar campos em linha

10

Estou tentando classificar dentro de uma linha de entrada em um número desconhecido de campos:

Entrada:

ab bc
bc ab
cd ef bc 
bc cd ef
cd bc ab
ef ab bc cd gh

Resultado:

ab bc
ab bc
bc cd ef
bc cd ef
ab cb cd
ab bc cd ef gh

Eu tenho usado algo como, awk '{if($2 < $1) print $2,$1;else print}'mas parece que ficaria bagunçado em mais de dois campos. Qualquer ajuda?

Chris
fonte

Respostas:

8

Uma maneira de usar perl:

perl -lane 'printf qq[%s\n], join q[ ], sort @F' infile

Resultado:

ab bc
ab bc
bc cd ef
bc cd ef
ab bc cd
ab bc cd ef gh
Birei
fonte
2
desde que você está usando -l, você não precisa imprimir uma nova linha. print join " ", sort @Fserá suficiente.
Glenn Jackman
6

Uma maneira de usar o GNU awk:

awk '{ 
    split($0, arr); 
    asort(arr); 
    for (i=1; i<=length(arr); i++) { 
        printf "%s ", arr[i] }; 
        printf RS 
    }
' infile

Resultado:

ab bc 
ab bc 
bc cd ef 
bc cd ef 
ab bc cd 
ab bc cd ef gh
Birei
fonte
2

Aqui está outra perlsolução, semelhante à resposta do @ Birei, mas mais concisa:

$ perl -anle 'print "@{[sort @F]}"' file
ab bc
ab bc
bc cd ef
bc cd ef
ab bc cd
ab bc cd ef gh
cuonglm
fonte
1

No shell script:

while read n    
do
   echo $(echo $n | tr " " "\n" | sort )
done < infile

(Isso bifurca muito, prefere a solução perl ou gnu awk)

Emmanuel
fonte