2 回答

TA貢獻1808條經驗 獲得超4個贊
使用列表理解將字符串數據轉換為整數,然后轉換為字節:
>>> lst = ['0x01','0xfe','0x02','0xff']
>>> d = bytes([int(x,0) for x in lst])
>>> d
b'\x01\xfe\x02\xff'
我假設您確實想要一個字節字符串,而不是 Unicode 字符串,因為它看起來像字節數據。
要創建顯示字符串,請格式化文字反斜杠并使用十六進制值設置 x。您可以通過切片字符串來獲取十六進制值0x,但為了格式一致性(例如兩位數,小寫),您仍然可以轉換為整數,然后使用格式字符串:
>>> lst = ['0x43','0xfe','0x02','0xff']
>>> bytes([int(x,0) for x in lst]) # actual byte string shows printable ASCII
b'C\xfe\x02\xff'
>>> d = ''.join([f'\\x{int(v,0):02x}' for v in lst]) # display string of hex escape codes
>>> d
'\\x43\\xfe\\x02\\xff'
>>> print(d)
\x43\xfe\x02\xff

TA貢獻1813條經驗 獲得超2個贊
我認為你可以做這樣的事情。
print (''.join(['\\'+x for x in lst]))
其輸出將是:
\0x01\0xfe\0x02\0xff
如果你想刪除前導 0,那么你可以這樣做:
print((''.join(lst)).replace('0x',r'\x'))
它會給你:
\x01\xfe\x02\xff
添加回答
舉報