쉘 : 바이너리 파일의 바이트를 읽고 16 진수로 인쇄하는 방법? 내가 가지고있는 이진 파일의

쉘에서 내가 가지고있는 이진 파일의 바이트를 읽고 16 진수로 출력을 인쇄하는 방법은 무엇입니까?



답변

사용하다 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입니다 .

od -t x1 FILE

또는

od -x FILE

od 미세 조정을위한 많은 옵션이 있습니다.


답변

우리가 od와 있는 동안 hexdump두 가지 더 유사한 도구가 있습니다.

  • hd (bsdmainutils에서)
  • xxd (Vim의 일부)

샘플 출력 :

$ 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

답변

내 두 센트 :

tail -f streamfile | hexdump -C

나는 당신이 hexdump 라이브를 볼 수있는 동안 현재 버퍼링 파일을 마무리하고 있기 때문에 이것을 좋아합니다. 유닉스의 모든 것은 파일이며, 우리는 다양한 문제 tail와 같은 명령을 쉽게 연결 hexdump하고 해결할 수 있다는 것을 잊지 마십시오 .


답변

mc 

자정 사령관은 또 다른 옵션입니다. 모든 유닉스 맛에 사용할 수 있는지 모르겠습니다. 먼저 다운로드해야 할 수도 있습니다.
F3 F4내부 편집기 / 16 진 모드로 볼 수 있습니다.


답변

바이너리 파일 내에서 텍스트를 검색해야 할 때 od를 c와 x1과 함께 사용합니다.

$ echo "Some text..." | od -t c -t x1
0000000   S   o   m   e       t   e   x   t   .   .   .  \n
         53  6f  6d  65  20  74  65  78  74  2e  2e  2e  0a
0000015