Usando algumas ferramentas como grep, sed, awk, & você pode implementar algumas respostas de este outro site . Eles incluem (se você quisesse b então tudo o mais normalmente):
Retire as linhas na ordem desejada, começando com a primeira, depois a segunda, etc. "
grep '^b' myfile > outfile
grep '^d' myfile >> outfile
grep -v '^b' myfile | grep -v '^d' | sort >> outfile
Adicione primeiro a "chave de classificação" personalizada, depois classifique e remova-a depois:
sed -e 's/^b/0&/' -e t -e 's/^d/1&/' -e 't' -e 's/^/2/' |
sort |
sed 's/^.//'
O mais fácil parece ser:
use a language such as Perl, Python or Ruby that lets you easily specify a custom sort function.
perl -e 'print sort {($b =~ /^[bd]/) - ($a =~ /^[bd]/) ||
$a cmp $b} <>'
python -c 'import sys; sys.stdout.write(sorted(sys.stdin.readlines(), key=lambda s: (0 if s[0]=="b" else 1 if s[0]=="d" else 2), s))'
Ou tente o awk (nenhuma explicação dada, YMMV):
sort myfile | awk '$0 ~ /^b/ || $0 ~ /^d/ {print} $0 !~ /^b/ && $0 !~ /^d/ { a[f++] = $0 } END { for (word = 0; word < f; word++) { print a[word] } }'