ho scritto un brutto (forse) awk|sort|awk
linea per fare il lavoro. potrebbe essere fatto anche in un processo awk, tuttavia, sono un po 'pigro, basta andare al modo sporco e veloce.
echo yourStr|awk '{
split($0,o); for(x in o) print length(o[x]),o[x]}'|sort -n|awk '!p{printf $2;p=$1;next}$1==p{printf " "$2}$1!=p{printf "\n"$2;p=$1}'
diamo un esempio:
"Hello stackoverflow how are you today foo bar xoo yoo ooo"
prova con riga sopra:
kent$ echo "Hello stackoverflow how are you today foo bar xoo yoo ooo"|awk '{
split($0,o); for(x in o) print length(o[x]),o[x]}'|sort -n|awk '!p{printf $2;p=$1;next}$1==p{printf " "$2}$1!=p{printf "\n"$2;p=$1}'
are bar foo how ooo xoo yoo you
Hello today
stackoverflow
di prova con il primo esempio:
kent$ echo "A a b B cc ca cd" |awk '{
pipe quote> split($0,o); for(x in o) print length(o[x]),o[x]}'|sort -n|awk '!p{printf $2;p=$1;next}$1==p{printf " "$2}$1!=p{printf "\n"$2;p=$1}'
a A b B
ca cc cd
+ 1 problema interessante ... – Kent
Aggiunta una soluzione di processo singola usando 'GNU awk'. Se sei interessato vedi sotto. Saluti. – Steve