「純粋な」プレーンなビットのバイナリシーケンスをダンプするにはどうすればよいですか?
たとえば、私はこれを持っています:
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
出力を必要な形式に解析するのは簡単です。
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 ' '