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

일부 필드에는 다른 필드보다 더 많은 공백이 포함되어 있고 일부 행에는 특정 열이 누락되어 있으므로 필드 번호로 데이터를 추출하는 것은 까다로울 수 있습니다. 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

더 이상 허위 공백이 없지만 유형 필드가 필드에 혼합된다는 단점이 있습니다. 물론 모든 것이 하나로 필요한 경우 이를 수행할 수 있는 방법이 있습니다.

관련 정보