有 awk 列偏移量吗?

有 awk 列偏移量吗?

我正在尝试创建一个与输出一起使用的命令来检查分区类型和名称。我刚刚发现了一个解决方案,使用awk或者也许sfdisk

这是我的基本输出:

root@debian:/home/si# sudo sfdisk -l /dev/sda --quiet | awk '{print $0}'
Périphérique Amorçage   Début      Fin Secteurs Taille Id Type     
/dev/sda1    *           2048  2000895  1998848   976M 83 Linux    
/dev/sda2             2000896 86962175 84961280  40,5G 8e LVM Linux

现在让我们过滤 列$1$7然后$8

root@debian:/home/si# sudo sfdisk -l /dev/sda --quiet | awk '{print $1, $7, $8}'
Périphérique Id Type  
/dev/sda1 83 Linux    
/dev/sda2 LVM Linux  

列上似乎有一个偏移量,因为LVM上的值/dev/sda2应该属于该Type列,所以$8如果我是对的,则该列。

如何awk显示列?有没有我错过的过滤器?

在我看来,输出列显示应该像(|手动添加)

$1           |      $2  |     $3   |   $4     |    $5    |   $6   | $7 | $8
Périphérique | Amorçage |  Début   |   Fin    | Secteurs | Taille | Id | Type     
/dev/sda1    |*         |  2048    | 2000895  |  1998848 |  976M  | 83 | Linux    
/dev/sda2    |          |  2000896 | 86962175 |84961280  | 40,5G  | 8e | LVM Linux

答案1

你的图片是错误的。最后一行看起来像这样:

      1      |     2   |    3     |     4    |    5   |  6 |  7  | 8
/dev/sda2    | 2000896 | 86962175 |84961280  | 40,5G  | 8e | LVM | Linux

由于某些字段比其他字段包含更多的空格,并且某些行缺少某些列,因此尝试按字段编号提取数据将会很棘手。考虑使用可用的 JSON 输出,sfdisk这在很大程度上可以避免这些问题:

sudo sfdisk -J /dev/nvme0n1 |
  jq -r '.partitiontable.partitions[]|[.node, .size, .type]|@tsv'

这会输出类似的内容(在我的系统上):

/dev/nvme0n1p1  409600  C12A7328-F81F-11D2-BA4B-00A0C93EC93B
/dev/nvme0n1p2  2097152 0FC63DAF-8483-4772-8E79-3D69D8477DE4
/dev/nvme0n1p3  493076480   E6D6D379-F507-44C2-A23C-238F2A3DF928

您会注意到,这使用 UUID 来标识分区类型而不是名称,因此您可能需要根据您的目标将其映射回人类可读的内容。

答案2

的输出sfdisk由物理列而不是逻辑字段格式化。

要使用 Awk 解析它,请使用 GNU Awk。 GNU Awk 支持解析固定列。

这适用于我的安装sfdisk

$ sudo sfdisk -l /dev/sda --quiet | gawk -v OFS="|" -v FIELDWIDTHS='11 4 9 9 9 6 3 40'  '$1=$1'
Device     |Boot|    Start|      End|  Sectors|  Size| Id| Type
/dev/sda1  |*   |     2048| 50427903| 50425856|   24G| 83| Linux
/dev/sda2  |    | 50429950| 52426751|  1996802|  975M|  5| Extended
/dev/sda5  |    | 50429952| 52426751|  1996800|  975M| 82| Linux swap / Solaris

请注意,字段不会删除空格。

我们可以玩的另一个技巧是利用唯一缺少的字段是启动标志*。我们可以在其位置粘贴一些替代字符,例如!然后让 Awk 使用以下命令重新解析记录$1=$1

$ sudo sfdisk -l /dev/sda --quiet  | awk -v OFS="," 'NR > 1 && $2 != "*" { $0=substr($0, 1, 11) "!" substr($0, 13) } ; $1=$1'
Device,Boot,Start,End,Sectors,Size,Id,Type
/dev/sda1,*,2048,50427903,50425856,24G,83,Linux
/dev/sda2,!,50429950,52426751,1996802,975M,5,Extended
/dev/sda5,!,50429952,52426751,1996800,975M,82,Linux,swap,/,Solaris

我们不再有虚假的空白,但缺点是,类型字段会被混入字段中,当然;如果需要一体成型,有很多方法。

相关内容