我有一个两列的文件;该文件已按照我想要的方式在第 1 列中排序。我想对第 1 列每个类别中的第 2 列进行排序。但是,sort
不理解第 1 列的排序顺序。
正常的方法(来自堆栈上的类似问题)是这样的:
sort --stable -k1,1 -k2,2n
但我无法指定 k1 的排序,因为它是任意的。
输入示例:
C 2
C 1
A 2
A 1
B 2
B 1
和输出:
C 1
C 2
A 1
A 2
B 1
B 2
答案1
您可以使用 awk 为每个块开始新的排序:
% awk -v cmd="sort -k2,2" '$1 != prev {close(cmd); prev=$1} {print | cmd}' foo
C 1
C 2
A 1
A 2
B 1
B 2
$1 != prev {close(cmd); prev=$1}
- 当保存的值不同时,我们有一个新的块,因此我们关闭任何先前启动的块sort
{print | "sort -k2,2"}'
将输出通过管道传输到sort
,如果它尚未运行则启动它(awk 可以跟踪它启动的命令)