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

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 实用程序?

最佳答案

使用 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

关于linux - 对具有非均匀字段的行进行排序,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48792153/

10-16 07:19