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