답변:
사용하다 hexdump(1)
$ hexdump -x /usr/bin/hexdump
0000000 feca beba 0000 0300 0001 0700 0080 0300
0000010 0000 0010 0000 5080 0000 0c00 0000 0700
0000020 0000 0300 0000 00a0 0000 b06f 0000 0c00
0000030 0000 1200 0000 0a00 0100 0010 0000 107c
0000040 0000 0c00 0000 0000 0000 0000 0000 0000
0000050 0000 0000 0000 0000 0000 0000 0000 0000
...
od
. vi 스타일의 16 진 편집기도 hexer
있습니다.
hexdump -e '"\\\x" /1 "%02x"' filename
10
은 16의 16 인 오프셋으로 시작합니다 . 2 바이트 표현은 시스템 의 엔디안 에 따라 다릅니다 . man hexdump
자세한 내용을 입력 하십시오.
od -t x1
내가 좋아하는 형식으로 찾을 것 입니다.
od -t test
내가 얻은 줄od: invalid character 't' in type string 'test'
--t
od --version od (GNU coreutils) 7.4
우리가 od
와 있는 동안 hexdump
두 가지 더 유사한 도구가 있습니다.
샘플 출력 :
$ hd /usr/bin/od | head
00000000 7f 45 4c 46 01 01 01 00 00 00 00 00 00 00 00 00 |.ELF............|
00000010 02 00 03 00 01 00 00 00 20 8e 04 08 34 00 00 00 |........ ...4...|
00000020 a4 a2 00 00 00 00 00 00 34 00 20 00 08 00 28 00 |........4. ...(.|
00000030 1b 00 1a 00 06 00 00 00 34 00 00 00 34 80 04 08 |........4...4...|
00000040 34 80 04 08 00 01 00 00 00 01 00 00 05 00 00 00 |4...............|
00000050 04 00 00 00 03 00 00 00 34 01 00 00 34 81 04 08 |........4...4...|
00000060 34 81 04 08 13 00 00 00 13 00 00 00 04 00 00 00 |4...............|
00000070 01 00 00 00 01 00 00 00 00 00 00 00 00 80 04 08 |................|
00000080 00 80 04 08 c4 9d 00 00 c4 9d 00 00 05 00 00 00 |................|
00000090 00 10 00 00 01 00 00 00 00 a0 00 00 00 20 05 08 |............. ..|
$ xxd /usr/bin/od | head
0000000: 7f45 4c46 0101 0100 0000 0000 0000 0000 .ELF............
0000010: 0200 0300 0100 0000 208e 0408 3400 0000 ........ ...4...
0000020: a4a2 0000 0000 0000 3400 2000 0800 2800 ........4. ...(.
0000030: 1b00 1a00 0600 0000 3400 0000 3480 0408 ........4...4...
0000040: 3480 0408 0001 0000 0001 0000 0500 0000 4...............
0000050: 0400 0000 0300 0000 3401 0000 3481 0408 ........4...4...
0000060: 3481 0408 1300 0000 1300 0000 0400 0000 4...............
0000070: 0100 0000 0100 0000 0000 0000 0080 0408 ................
0000080: 0080 0408 c49d 0000 c49d 0000 0500 0000 ................
0000090: 0010 0000 0100 0000 00a0 0000 0020 0508 ............. ..
또는 바이트를 한 번에 하나씩 읽고 자신의 형식으로 인쇄하려면 다음과 같이 시도하십시오.
while read -n 1 byte; do
ord=$(printf "%b" "${byte:-\000}" |
od -t x1 |
{ read offset hex; echo $hex; })
echo "$ord"
done </usr/bin/od
샘플 출력 :
7f
45
4c
46
01
01
01
00
00
00
while
루프 백 슬래시와 (공백 문자)의 경우 ksh93에 반대하고 떠들썩한 파티에 (로) 줄 바꿈 문자 작동하지 않으며, 8 비트 세트 바이트 UTF8 로케일에서 제대로 작동합니다. 또한,이 "OD"필요가 없습니다, 당신은 사용할 수 있습니다printf '%02x\n' "'$byte"
offset
여기서는 일종의 "더미 변수"입니다. 실용적이지 않습니다. 단지 자리 표시 자로 사용됩니다 hex
. 이것은 때때로 read
변수가 파란색에서 나오는 부정적인 결과로 가독성에 영향을 미칩니다 .
$offset
는 서브 쉘에 의해 제한되므로 문제로 보지 않습니다.
내 두 센트 :
tail -f streamfile | hexdump -C
나는 당신이 hexdump 라이브를 볼 수있는 동안 현재 버퍼링 파일을 마무리하고 있기 때문에 이것을 좋아합니다. 유닉스의 모든 것은 파일이며, 우리는 다양한 문제 tail
와 같은 명령을 쉽게 연결 hexdump
하고 해결할 수 있다는 것을 잊지 마십시오 .
for((i=0;i<100;i++));do echo $i >>tst2.bin;sleep 1;done&
그것으로 테스트 thx를 모니터링하기 위해 잘 작동합니다 :)