input.txt
다음 단락이 포함된 파일이 있습니다 .
[730480.910190] [MACSTATUSIND] ACTIND_ParseMACSTATUS:
[730480.910205] fe 0a 39 01 0a 00 51 e7 ba 9d c7 0d 00 00 00 00 ..9...Q....
[730480.910220] 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ...........
[730480.910233] 00 00 00 00 00 00 00 00 00 00 xx xx xx xx xx xx .....:bC.B.
[730480.910247] xx xx yy yy yy yy yy yy zz zz 64 34 e8 ff 00 00 ......d4...
[730480.910190] [MACSTATUSIND] ACTIND_ParseMACSTATUS:
[730480.910205] fe 0a 39 01 0a 00 51 e7 ba 9d c7 0d 00 00 00 00 ..9...Q....
[730480.910220] 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ...........
[730480.910233] 00 00 00 00 00 00 00 00 00 00 aa bb cc dd ee ff .....:bC.B.
[730480.910247] gg hh ii jj kk ll mm nn oo pp 64 34 e8 ff 00 00 ......d4...
위의 데이터를 기반으로 각 단락마다 세 개의 열을 만든 다음 행을 다른/새 파일에 저장하려고 합니다 new.txt
.
출력: new.txt
col1 col2 col3
------- ---- ------
xxxxxxxx | yyyyyy | zzzz
aabb..gghh | ii..nn | oopp
노트: 위의 단락 로그가 파일에서 여러 번 반복됩니다. 모든 단락에는[MACSTATUSIND] ACTIND_ParseMACSTATUS:
답변1
awk 'BEGIN { print " col1 | col2 | col3" }
/^\[730480.910233\] / {SA = $12 $13 $14 $15 $16 $17}
/^\[730480.910247\] / { print SA $2 $3 " | " $4 $5 $6 $7 $8 $9 " | " $10 $11}
' input.txt > new.txt