十六进制数的位异或运算

2022-02-25 00:00:00 python bit-manipulation hex xor

问题描述

如何在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

相关文章