十六进制数的位异或运算
问题描述
如何在Python中对十六进制数进行异或运算?例如,我想对'ABCD'
和'12EF'
进行异或运算,答案应该是'B922'
。
我使用了下面的代码,但它给出了错误的结果。
# xor two strings of different lengths
def strxor(a, b):
if len(a) > len(b):
return "".join(["%s" % (ord(x) ^ ord(y)) for (x, y) in zip(a[:len(b)], b)])
else:
return "".join(["%s" % (ord(x) ^ ord(y)) for (x, y) in zip(a, b[:len(a)])])
key = '12ef'
m1 = 'abcd'
print(strxor(key, m1))
解决方案
哇。你真的把它复杂化了很远的距离。尝试:
>>> print(hex(0x12ef ^ 0xabcd))
0xb922
您似乎至少忽略了这些方便的事实:
- Python具有对十六进制整数文字的本机支持,前缀为
0x
。 - 十六进制";仅是演示文稿的详细信息;以二进制形式进行算术,然后将结果打印为祸不单行。
- 输入格式(十六进制文字)和输出之间没有连接,Python变量中没有十六进制数。
hex()
函数可用于将任何数字转换为十六进制字符串以供显示。
如果已经有字符串形式的数字,可以使用int()
函数转换为数字,方法是提供预期的基数(十六进制数字为16):
>>> print(int("12ef", 16))
4874
您可以进行两次转换,执行异或运算,然后再转换回祸不单行:
>>> print(hex(int("12ef", 16) ^ int("abcd", 16)))
0xb922
相关文章