HexString для упакованной строки EBCDIC - PullRequest
1 голос
/ 13 октября 2019

Мне нужно преобразовать шестнадцатеричные данные '767f440128e1a00a' в упакованную строку EBCDIC. Я хочу, чтобы все result результатов были в одной строке, но python выдает ошибку Unicode UnicodeDecodeError: 'utf-8' codec can't decode byte 0xe1 in position 0: unexpected end of data

s='767f440128e1a00a'
output = []
DDF = [1]
distance = 0
for y in range (1,len(s[2:])):
    for x in DDF:
        if s[2:][distance:x*2+distance]!='':
            output.append(s[2:][distance:x*2+distance]) 
        else:
            continue
        distance += x*2
print(output)
final=[]
result=''
bytearrya=[]
for x in output:
    result=(str(bytearray.fromhex(x).decode()))
    x = codecs.decode(x, "hex")
    final.append(x)

1 Ответ

0 голосов
/ 13 октября 2019

Вот код, основанный на Python-байтовом представлении шестнадцатеричной строки, которая является EBCDIC , в которой упоминается «Согласно this , вам необходимо использовать« cp500 »для декодирования»

Codec / Aliases                            / Languages
cp500 / EBCDIC-CP-BE, EBCDIC-CP-CH, IBM500 / Western Europe
my_string_in_hex = '767f440128e1a00a'
my_bytes = bytearray.fromhex(my_string_in_hex)
print(my_bytes)

my_string = my_bytes.decode('cp500')
print(my_string)

Выход:

enter image description here

...