これは以下に関連しています。一致するものがある場合、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/
)으로 수정할 수 있고, 전체 파일을 메모리에 로드하지 않으며, 가장 중요한 것은 수동 상태를 작성할 필요가 없다는 것입니다. 기계.