2進数と文字列の両方の文字を含む文字列があり、最初に2進数に変換してから、16進数に変換したいと思います。
文字列は次のとおりです。
<81>^Q<81>"^Q^@^[)^G ^Q^A^S^A^V^@<83>^Cd<80><99>}^@N^@^@^A^@^@^@^@^@^@^@j
この文字列をPythonに変換して、16進形式の出力が以下のようになるようにするにはどうすればよいですか?
24208040901811001B12050809081223431235113245422F0A23000000000000000000001F
あなたはこのようにordとhexを使うことができます:
>>> s = 'some string'
>>> hex_chars = map(hex,map(ord,s))
>>> print hex_chars
['0x73', '0x6f', '0x6d', '0x65', '0x20', '0x73', '0x74', '0x72', '0x69', '0x6e', '0x67']
>>> hex_string = "".join(c[2:4] for c in hex_chars)
>>> print hex_string
736f6d6520737472696e67
>>>
または、組み込みのエンコーディングを使用します。
>>> s = 'some string'
>>> print s.encode('hex_codec')
736f6d6520737472696e67
>>>
>>> import binascii
>>> s = '2F'
>>> hex_str = binascii.b2a_hex(s)
>>> hex_str
>>> '3246'
OR
>>>import binascii
>>> hex_str = binascii.hexlify(s)
>>> hex_str
>>> '3246'
>>>
より高速なソリューションを参照してください。
from timeit import Timer
import os
import binascii
def testSpeed(statement, setup = 'pass'):
print '%s' % statement
print '%s' % Timer(statement, setup).timeit()
setup = """
import os
value = os.urandom(32)
"""
# winner
statement = """
import binascii
binascii.hexlify(value)
"""
testSpeed(statement, setup)
# loser
statement = """
import binascii
value.encode('hex_codec')
"""
testSpeed(statement, setup)
結果:
import binascii
binascii.hexlify(value)
2.18547999816
value.encode('hex_codec')
2.91231595077