sql – 如何设置sort(1)以使用自定义归类?

我有一个文本文件,每行包含一个记录,我想按字母顺序排序,除了我想要’ – ‘在'[‘和’]’之后排序. (自然排序顺序在方括号之前有’ – ‘.)有没有办法修改sort(1)用于实现此目的的排序规则?

解决方法

一种方法是替换未出现在数据中的字符,但在括号后排序(在某些语言环境中).

sed 's/-/|/g' inputfile | LC_ALL=C sort | sed 's/|/-/g' > outputfile

这显然不是一个理想的解决方案.

dawei