我有一个包含以下名称的文本文件:
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/