パーティションのタイプと名前を解決するために、出力で機能するコマンドを生成しようとしています。ちょうどまたは多分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
一部のフィールドには他のフィールドよりも多くのスペースが含まれており、一部の行には特定の列がないため、フィールド番号でデータを抽出するのは難しい場合があります。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を使用してパーティションの種類を識別するため、目的に応じて人間が読める項目に再マップする必要があります。
答え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
もはや偽空白がないが、型フィールドがフィールドに混在するという欠点がある。もちろん、すべてが一つで必要な場合にこれを行う方法があります。