web-dev-qa-db-ja.com

行番号とASCIIの解釈なしで、ファイルから生のバイナリ 'ビット'をダンプするにはどうすればよいですか?

「純粋な」プレーンなビットのバイナリシーケンスをダンプするにはどうすればよいですか?

たとえば、私はこれを持っています:

 0000000: 10001001 01010000 01001110 01000111 00001101 00001010  .PNG..
 0000006: 00011010 00001010 00000000 00000000 00000000 00001101  ......
 000000c: 01001001 01001000 01000100 01010010 00000000 00000000  IHDR..
 0000012: 00000010 01011000 00000000 00000000 00000001 10010000  .X....
 0000018: 00001000 00000010 00000000 00000000 00000000 11111101  ......
 000001e: 01010111 10001001 11001111 00000000 00000000 00000000  W.....
 0000024: 00000111 01110100 01001001 01001101 01000101 00000111  .tIME. 

左側の行番号と右側のASCIIは私にとって問題です。これを削除してみました:

xxd -b /root/Desktop/image.png | sed -r "s/\d32{3,}.*//g" | sed "s/.*://" | sed "s/\d32//g"

しかし、私は成功しませんでした:

 100010010101000001001110010001110000110100001010.PNG..
 000110100000101000000000000000000000000000001101......
 010010010100100001000100010100100000000000000000IHDR..
 000000100101100000000000000000000000000110010000.X....
 000010000000001000000000000000000000000011111101......
 010101111000100111001111000000000000000000000000W.....
 000001110111010001001001010011010100010100000111.tIME.

'xxd'や 'hexdump'のようなツール、またはファイルからクリーンなバイナリシーケンスを生成できるものはありますか?

例えば、

 01010101000100100100010100100010000010101010101010101001011
 10101010101010100100101010101010100000010001000100001000000
4
learnerX

出力を必要な形式に解析するのは簡単です。

xxd -b /root/Desktop/image.png | cut -d: -f 2 | sed 's/  .*//; s/ //g'

cutは行番号を削除し、sedは最初に最後の列を削除します(s/ .*//は、2つの連続するスペースの後に続くすべてを削除します)、次にすべての単一スペースを削除します。

awkを使用することもできます。

xxd -b ~/a.png | awk '{print $2$3$4$5$6$7}'

またはPerl:

xxd -b ~/a.png | head -1 | Perl -lane 'print join "",@F[1..6]'

またはcoreutils:

xxd -b ~/a.png | cut -d" " -f2-7 | tr -d ' '
6
terdon