排序具有非均匀字段的行

时间:2018-02-14 16:41:58

标签: linux bash awk sed grep

我有一个包含如下名称的文本文件:

cup-1.5.1-1_d03.rpm
cup-1.5-2_d03.rpm
cup-1.5.1-2_d03.rpm
cup-1.5-3_d03.rpm

我知道cup-1.5.1-2_d03.rpm应该是最新版本。有没有办法正确排序,以便输出看起来像,

cup-1.5-2_d03.rpm
cup-1.5-3_d03.rpm
cup-1.5.1-1_d03.rpm
cup-1.5.1-2_d03.rpm

我试过

$ grep -o -P '(?<=cup-)[0-9]+.[0-9]+.*[0-9]+(?=.*.rpm)' a.txt |  tr '.' ' ' | tr '-' ' ' | sort -k4
1 5 2_d03
1 5 3_d03
1 5 1 1_d03
1 5 1 2_d03

但不确定如何为整个字符串实现它。我还有另一个文件有一些不同的版本,其中字段为-k5

$ cat b.txt
dup-1.1.1-3_d03.rpm
dup-1.1.1.1-1_d03.rpm
dup-1.1.1-1_d03.rpm

在这里,我希望得到一个输出:

dup-1.1.1-1_d03.rpm
dup-1.1.1-3_d03.rpm
dup-1.1.1.1-1_d03.rpm

如果可能的话,有没有办法以编程方式对这两个文件进行排序而不依赖rpm实用程序?

1 个答案:

答案 0 :(得分:3)

使用sort -V(版本):

sort -V file

cup-1.5-2_d03.rpm
cup-1.5-3_d03.rpm
cup-1.5.1-1_d03.rpm
cup-1.5.1-2_d03.rpm