Инструмент для преобразования файла HEX в набор символов ASCII?

45781
Aaron

Вопрос:

  • Есть ли известный инструмент для преобразования файла, состоящего из 2-байтового Hex в ASCII ?

Примечание: - Сохраняйте смещение файла в байтах

Пример:

Содержание файла:

00000000 0054 0065 0073 0074 0020 0054 0065 0073 00000008 0074 0020 0054 0065 0073 0074 0020 0054 00000016 0065 0073 0074 0020 0054 0065 0073 0074 00000024 0020 0054 0065 0073 0074 0020 0054 0065 00000032 0073 0074 0020 0054 0065 0073 0074 0020 00000040 0054 0065 0073 0074 000a 0054 0065 0073 00000048 0074 0020 0054 0065 0073 0074 0020 0054 00000056 0065 0073 0074 0020 0054 0065 0073 0074 00000064 0020 0054 0065 0073 0074 0020 0054 0065 

Ожидаемый результат

00000016 0065 0073 0074 0020 0054 0065 0073 0074 |est Test Test Te| 00000032 0073 0074 0020 0054 0065 0073 0074 0020 |st Test Test.Tes| 00000048 0074 0020 0054 0065 0073 0074 0020 0054 |t Test Test Test| 00000064 0020 0054 0065 0073 0074 0020 0054 0065 | Test Test Test | 
2

3 ответа на вопрос

5
Dennis Williamson

Ваш входной файл выглядит так, как будто он был создан с использованием чего-то вроде этого:

hexdump -e '"%08_ad " 8/1 "%04x "' -e '"" 0/0 "" "\n"' original_file 

К сожалению, xxd -rне может справиться с десятичными смещениями.

Вот короткая программа Gnu AWK, которая даст вам результат, который вы ищете:

gawk '; printf "|\n"}' input_file 

Если вы используете AWK кроме gawk, вы можете использовать эту strtonum()функцию здесь .

Вот еще один способ сделать то же самое, что и gawkскрипт выше:

cut -c 11- input_file | sed 's/\<00//g' | xxd -r -p | hexdump -e '"%08_ad " 8/1 "%04x " ""' -e '" |" 8/1 "%_p" "|\n"' 

Если вместо этого вы хотите преобразовать ваш входной файл в текст:

cut -c 11- input_file | xxd -r -p 
@ Аарон: я добавил дополнительную информацию. Dennis Williamson 13 лет назад 0
Был немного другой сценарий использования для вывода отдельных символов вручную только в приглашении ввода, и просто использовал это: `echo '0x32' | xxd -r` Пока не нашли разницы при использовании `-p` для одного или нескольких символов. Pysis 6 лет назад 0
4
Ignacio Vazquez-Abrams
iconv -f utf-16be -t ascii input.txt 
`iconv` поставляется с предустановленной Mac OS X :), поэтому не игнорируйте это решение из-за страха отвлечь ваше внимание на менеджер пакетов. Sridhar-Sarnobat 8 лет назад 0
1
asoundmove

To remove 0x00, on unix you can use:

tr -d '\0' 

To display you can use object dump (od) and filter the output.

od -w$1 -v -t x1a $2 

This gives you the raw output which you can then filter with awk (or other script).

od -w$1 -v -t x1a $2 | awk '$0~/^[0-9A-Fa-f]/ ; printf " "; next} ; printf "\n"}' 

Replace $2 with the amount of bytes you want displayed. Gives you the first step, you then need to filter every second byte (0x00)

I hope this helps.

The example below is on plain ascii, but doing so on a 2-byte file would be very much the same.

00000000 23 21 2f 62 69 6e 2f 73 68 0d 0a 0d 0a 23 20 6f |#!/bin/sh....# o| 00000010 64 20 2d 77 24 31 20 2d 76 20 2d 74 20 78 31 61 |d -w$1 -v -t x1a| 00000020 20 24 32 20 7c 20 61 77 6b 20 27 24 30 7e 2f 5e | $2 | awk '$0~/^| 00000030 5b 30 2d 39 41 2d 46 61 2d 66 5d 2f 20 7b 70 72 |[0-9A-Fa-f]/ ' || 00000060 20 73 65 64 20 27 73 2f 5e 5b 30 2d 39 61 2d 66 | sed 's/^[0-9a-f| 00000070 41 2d 46 5d 2a 5b 20 09 5d 2a 2f 2f 27 20 7c 20 |A-F]*[ .]*//' | | 00000080 73 65 64 20 27 73 2f 5b 20 09 5d 5b 20 09 5d 2a |sed 's/[ .][ .]*| 00000090 2f 09 2f 67 27 0d 0a 6f 64 20 2d 77 24 31 20 2d |/./g'..od -w$1 -| 000000a0 76 20 2d 74 20 78 31 61 20 24 32 20 7c 20 61 77 |v -t x1a $2 | aw| 000000b0 6b 20 27 24 30 7e 2f 5e 5b 30 2d 39 41 2d 46 61 |k '$0~/^[0-9A-Fa| 000000c0 2d 66 5d 2f 20 7b 66 6f 72 20 28 69 3d 32 3b 20 |-f]/ ; printf " | 00000110 22 3b 20 6e 65 78 74 7d 20 7b 66 6f 72 20 28 69 |"; next} ; pr| 00000160 69 6e 74 66 20 22 5c 6e 22 7d 27 0d 0a |intf "\n"}'..| 0000016d 
Можете ли вы привести пример? Aaron 13 лет назад 0
Похоже, что у ignacio гораздо более простое решение ... asoundmove 13 лет назад 0

Похожие вопросы