awk列オフセットはありますか?

awk列オフセットはありますか?

パーティションのタイプと名前を解決するために、出力で機能するコマンドを生成しようとしています。ちょうどまたは多分awksfdisk

これは私のデフォルト出力です。

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

一部のフィールドには他のフィールドよりも多くのスペースが含まれており、一部の行には特定の列がないため、フィールド番号でデータを抽出するのは難しい場合があります。sfdisk次の問題のほとんどを回避できる利用可能なJSON出力を使用することをお勧めします。

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を使用してパーティションの種類を識別するため、目的に応じて人間が読める項目に再マップする必要があります。

おすすめ記事