다음 줄이 누락된 경우 해당 줄을 인쇄하세요.

다음 줄이 누락된 경우 해당 줄을 인쇄하세요.

これは以下に関連しています。一致するものがある場合、awkは2行を印刷します。그러나 내 명령에는 해결할 수 없는 버퍼링 문제가 있으므로 stderr를 완전히 무시하고 특정 줄이 누락된 출력을 찾는 것이 더 나은 접근 방식이라고 생각합니다.

그래서 내 출력은 다음과 같습니다

Gathering drive descriptors ...
Gathering data for drive 0 ...
Drive Model: DataTraveler 2.0
Gathering data for drive 1 ...
Drive name:  id1,sd@n5000cca17096
Drive Model: HUH721010AL4204
Drive Speed: 7200 RPMs
Drive Temp:  41 C

Gathering data for drive 2 ...
Drive name:  id1,sd@n5000cca24156
Drive Model: HUH721010AL4204
Drive Speed: 7200 RPMs
Drive Temp:  41 C

Gathering data for drive 3 ...
Drive name:  id1,sd@n5000cca8749
Drive Model: HUH721010AL4204
Gathering data for drive 4 ...
Drive name:  id1,sd@n5000cca19183
Drive Model: HUH721010AL4204
Drive Speed: 7200 RPMs
Drive Temp:  41 C

Gathering data for drive 5 ...
Drive name:  id1,sd@n5000cca4607
Drive Model: HUSMH8010BSS204
Gathering data for drive 6 ...
Drive name:  id1,sd@n5000cca10152
Drive Model: HUH721010AL4204
Drive Speed: 7200 RPMs
Drive Temp:  41 C

Drive name누락된 행에 대한 Drive Speed드라이버 Drive Temp를 출력하고 싶습니다 .

출력은 다음과 같아야 합니다.

Drive name:  id1,sd@n5000cca8749
Drive name:  id1,sd@n5000cca4607

이것은 내 능력 밖의 일이지만 할 수 있다고 확신 awk하지만 사용할 계획은 없으며 awk작업을 완료하는 모든 것이 가능합니다(GNU 도구 없음). 감사해요!

ベストアンサー1

mawk및 다음을 사용하여 gawk정규식 및 다중 문자 RS(레코드 구분 기호) 를 지원합니다.

awk -v RS='Gathering data' -F'\n' '/Drive name/ && !/Drive Speed/ && !/Drive Temp/{print$(NF-2)}' file

이를 지원하지 않는 경우 awk입력을 필터링하여 폼 피드와 같은 단일 문자로 바꿀 수 있습니다.

awk '/Gathering data/{$0="\f"} 1' file | awk -v RS='\f' -F'\n' '/Drive name/ && !/Drive Speed/ && !/Drive Temp/{print$(NF-2)}'

레코드의 행이 고정된 순서가 아닌 경우 이를 생략하여 전체 레코드를 인쇄한 {print ...}다음 grep 등을 사용하여 출력을 필터링할 수 있습니다.

이 접근 방식의 장점은 일치 조건을 명확한 방법(예: /Drive Speed: 7200 RPMs/대신 등 !/foo/ && !/bar/)으로 수정할 수 있고, 전체 파일을 메모리에 로드하지 않으며, 가장 중요한 것은 수동 상태를 작성할 필요가 없다는 것입니다. 기계.

おすすめ記事