【问题标题】:sort lines with nonuniform fields对具有非均匀字段的行进行排序
【发布时间】:2018-02-14 16:41:57
【问题描述】:

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

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 实用程序的情况下以编程方式对这两个文件进行排序?

【问题讨论】:

    标签: linux bash awk sed grep


    【解决方案1】:

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

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2023-03-05
      • 1970-01-01
      • 2023-03-18
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2014-01-24
      • 1970-01-01
      相关资源
      最近更新 更多