python - 十六进制数的按位异或

标签 python hex bit-manipulation 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

关于python - 十六进制数的按位异或,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11119632/

相关文章:

c++ - 这段代码如何计算一个数的奇偶性?

python - 使用 importlib 导入模块的别名

用于匹配文件中的十六进制数字的 Java 正则表达式

python - 获取 1 位在 python Long 对象中的位置

javascript - 如何在 Javascript 中将整数转换为具有固定长度的十六进制?

java - 十六进制的枚举类型使用 Java 返回错误的值?

algorithm - 为什么下面的代码有 o(logn) 的时间复杂度

python - 使用列表推导式向字典中的值加一

python - 如何让我的 Discord 机器人删除 channel 中的所有消息?

python - 删除列表中的重复项