Jak mogę przekonwertować szesnastkowy na zwykły ASCII w Pythonie?
Zauważ, że na przykład chcę przekonwertować „0x7061756c” na „paul”.
Jak mogę przekonwertować szesnastkowy na zwykły ASCII w Pythonie?
Zauważ, że na przykład chcę przekonwertować „0x7061756c” na „paul”.
Odpowiedzi:
Nieco prostsze rozwiązanie:
>>> "7061756c".decode("hex")
'paul'
.decode('hex')
w Pythonie 3. .decode('hex')
zastosowań binascii.unhexlify()
w Pythonie 2 .
codecs.decode("7061756c", "hex")
działa dla Pythona 2 i Pythona 3. Ale zwraca bytes()
łańcuch w Pythonie 3. Ale jest to rozsądne dla łańcucha ASCII.
Nie ma potrzeby importowania żadnej biblioteki:
>>> bytearray.fromhex("7061756c").decode()
'paul'
bytearray.fromhex("70 61 75 6C").decode()
'latin-1'
pozbędzie się wszelkich błędów, ale może spowodować kompletny bełkot, jeśli tekst nie jest w rzeczywistości Latin-1.
>>> txt = '7061756c'
>>> ''.join([chr(int(''.join(c), 16)) for c in zip(txt[0::2],txt[1::2])])
'paul'
Po prostu dobrze się bawię, ale najważniejsze części to:
>>> int('0a',16) # parse hex
10
>>> ''.join(['a', 'b']) # join characters
'ab'
>>> 'abcd'[0::2] # alternates
'ac'
>>> zip('abc', '123') # pair up
[('a', '1'), ('b', '2'), ('c', '3')]
>>> chr(32) # ascii to character
' '
spojrzy teraz na binascii ...
>>> print binascii.unhexlify('7061756c')
paul
fajnie (i nie mam pojęcia, dlaczego inni chcą cię zmusić do skakania przez obręcze, zanim pomogą).
Oto moje rozwiązanie podczas pracy z liczbami szesnastkowymi, a nie ciągami szesnastkowymi:
def convert_hex_to_ascii(h):
chars_in_reverse = []
while h != 0x0:
chars_in_reverse.append(chr(h & 0xFF))
h = h >> 8
chars_in_reverse.reverse()
return ''.join(chars_in_reverse)
print convert_hex_to_ascii(0x7061756c)
print convert_hex_to_ascii(123456)
.
Alternatywnie możesz też zrobić to ...
Python 2 Interpreter
print "\x70 \x61 \x75 \x6c"
Przykład
user@linux:~# python
Python 2.7.14+ (default, Mar 13 2018, 15:23:44)
[GCC 7.3.0] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> print "\x70 \x61 \x75 \x6c"
p a u l
>>> exit()
user@linux:~#
lub
Python 2 One-Liner
python -c 'print "\x70 \x61 \x75 \x6c"'
Przykład
user@linux:~# python -c 'print "\x70 \x61 \x75 \x6c"'
p a u l
user@linux:~#
Python 3 Interpreter
user@linux:~$ python3
Python 3.6.9 (default, Apr 18 2020, 01:56:04)
[GCC 8.4.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> print("\x70 \x61 \x75 \x6c")
p a u l
>>> print("\x70\x61\x75\x6c")
paul
Python 3 One-Liner
python -c 'print("\x70 \x61 \x75 \x6c")'
Przykład
user@linux:~$ python -c 'print("\x70 \x61 \x75 \x6c")'
p a u l
user@linux:~$ python -c 'print("\x70\x61\x75\x6c")'
paul
Przetestowane w Pythonie 3.3.2 Jest wiele sposobów, aby to osiągnąć, oto jeden z najkrótszych, wykorzystujący wyłącznie elementy dostarczane przez Pythona:
import base64
hex_data ='57696C6C20796F7520636F6E76657274207468697320484558205468696E6720696E746F20415343494920666F72206D653F2E202E202E202E506C656565656173652E2E2E212121'
ascii_string = str(base64.b16decode(hex_data))[2:-1]
print (ascii_string)
Oczywiście, jeśli nie chcesz niczego importować, zawsze możesz napisać własny kod. Coś bardzo podstawowego, takiego:
ascii_string = ''
x = 0
y = 2
l = len(hex_data)
while y <= l:
ascii_string += chr(int(hex_data[x:y], 16))
x += 2
y += 2
print (ascii_string)