【问题标题】:Convert hex string to int in Python在 Python 中将十六进制字符串转换为 int
【发布时间】:2010-09-17 14:15:24
【问题描述】:

如何在 Python 中将十六进制字符串转换为 int?

我可能将其命名为“0xffff”或只是“ffff”。

【问题讨论】:

标签: python string hex


【解决方案1】:

没有 0x 前缀,需要显式指定基数,否则无法分辨:

x = int("deadbeef", 16)

有了前缀0x,Python可以自动区分十六进制和十进制。

>>> print(int("0xdeadbeef", 0))
3735928559
>>> print(int("10", 0))
10

(您必须0指定为基数,以调用此前缀猜测行为;如果省略第二个参数int()将假定基数为10。)

【讨论】:

  • 这意味着您应该始终使用 16 作为第二个参数。显式优于隐式。
  • @bachsau,显然不真实。如果你想读取用户输入,允许以十六进制或十进制输入,以方便用户为准?
  • 好吧,我应该说:在这种特殊情况下!最初的问题是“如何转换十六进制字符串……”。如果你想把它留给用户,那么它是一个有用的功能,你是对的。
  • @DanLenski,它总是将十六进制字符串转换为正数。我希望将int("FFFF",16) 转换为-1。
  • @Nazar 已经很长时间了,所以此时这可能对您没有用处,但对于在这里偶然发现的任何其他人,如果需要应用二进制补码规则。这个答案可能会有所帮助stackoverflow.com/questions/1604464/twos-complement-in-python
【解决方案2】:

int(hexstring, 16) 可以解决问题,并且可以使用和不使用 0x 前缀:

>>> int("a", 16)
10
>>> int("0xa", 16)
10

【讨论】:

  • 16 位在哪里?
  • 十六进制基数。例如 8 是八进制
  • @Max 16 代表base 16。通常人们使用以 10 为基数(在 Python 中,当您没有将第二个参数传递给 int() 时,有一个隐含的 10),您从 0 开始,然后向上计数 0123456789(总共 10 位数字)回到 0 并将 1 添加到下一个单位。在基数 16(也称为“十六进制”或简称“十六进制”)中,您从 0 开始,然后向上计数 0123456789ABCDEF(总共 16 位数字)。 int 函数接受 2 到 36 中的任何数字作为基数,它只是扩展了字母表:基数 36 是 0123456789ABCEDFGHIJKLMNOPQRSTUVWXYZ
【解决方案3】:

在 Python 中将十六进制字符串转换为 int

我可能将其命名为 "0xffff" 或只是 "ffff"

要将字符串转换为 int,请将字符串连同要转换的基数一起传递给 int

这两个字符串都足以以这种方式进行转换:

>>> string_1 = "0xffff"
>>> string_2 = "ffff"
>>> int(string_1, 16)
65535
>>> int(string_2, 16)
65535

int推断

如果您传递 0 作为基数,int 将根据字符串中的前缀推断基数。

>>> int(string_1, 0)
65535

没有十六进制前缀,0xint 没有足够的信息来猜测:

>>> int(string_2, 0)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: invalid literal for int() with base 0: 'ffff'

文字:

如果您正在输入源代码或解释器,Python 将为您进行转换:

>>> integer = 0xffff
>>> integer
65535

这不适用于ffff,因为 Python 会认为您正在尝试编写一个合法的 Python 名称:

>>> integer = ffff
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
NameError: name 'ffff' is not defined

Python 数字以数字字符开头,而 Python 名称不能以数字字符开头。

【讨论】:

  • 值得重复“让 int 推断如果您将 0 作为基数传递,int 将根据字符串中的前缀推断基数。”如何像 python 解释器那样从十六进制或十进制(或二进制)转换为整数。
【解决方案4】:

对于任何给定的字符串 s:

int(s, 16)

【讨论】:

    【解决方案5】:

    在上面 Dan 的回答中添加:如果您为 int() 函数提供十六进制字符串,则必须将基数指定为 16,否则它不会认为您给它一个有效值。对于不包含在字符串中的十六进制数字,不需要指定基数 16。

    print int(0xdeadbeef) # valid
    
    myHex = "0xdeadbeef"
    print int(myHex) # invalid, raises ValueError
    print int(myHex , 16) # valid
    

    【讨论】:

      【解决方案6】:

      最糟糕的方式:

      >>> def hex_to_int(x):
          return eval("0x" + x)
      
      >>> hex_to_int("c0ffee")
      12648430
      

      请不要这样做!

      Is using eval in Python a bad practice?

      【讨论】:

      • 值得注意的是,eval 的速度也慢得离谱,而且还有其他所有问题。
      • 如果这是一个坏主意,那么提出它的意义何在?
      • 好点。部分是因为我认为它很有趣,部分是因为我在生产代码中看到过它。
      • 我可能应该注意到,在遇到int(s,16) 返回不正确值的问题后,我曾经这样做,导致我的运行时出现一些重大问题 (int(hex(value),16) == int(value) &gt;&gt;&gt; False)。提供给eval() 的字符串是安全的,并且返回的值是正确的。
      • 我觉得这很有趣,很有启发性,我很高兴它被发布了
      【解决方案7】:

      或者ast.literal_eval(这是安全的,不像eval):

      ast.literal_eval("0xffff")
      

      演示:

      >>> import ast
      >>> ast.literal_eval("0xffff")
      65535
      >>> 
      

      【讨论】:

      • 这可行,但比int(..., base=16)慢得多
      【解决方案8】:

      如果您使用的是 python 解释器,您只需输入 0x(您的十六进制值),解释器会自动为您转换。

      >>> 0xffff
      
      65535
      

      【讨论】:

      • 公平地说,这可能是最简单的答案。不要将十六进制字符串视为字符串,而是将其视为文字。作为记录,您还可以将十六进制文字传递给int(),它会起作用。
      【解决方案9】:

      格式化程序选项 '%x' % 似乎也适用于我的赋值语句。 (假设 Python 3.0 及更高版本)

      示例

      a = int('0x100', 16)
      print(a)   #256
      print('%x' % a) #100
      b = a
      print(b) #256
      c = '%x' % a
      print(c) #100
      

      【讨论】:

      • cmets 不正确。 print(b) 将输出256,而不是100print(c) 将输出100,而不是256。另请注意,c 是一个字符串,但 a 不是,所以您的答案实际上将 int 转换为字符串,而不是相反(这就是问题所在)。
      • 感谢您的意见,我同意我的回答不正确,现在我已经解决了。但是,我意识到部分答案如上所述是多余的,即使用 int(string, base),但我相信,答案的其余部分仍然为帖子添加了更多选项。同意吗?
      • 不相关;这是关于从基数 16 转换为基数 10,而不是相反
      【解决方案10】:

      处理十六进制、八进制、二进制、整数和浮点数

      使用标准前缀(即 0x、0b、0 和 0o),此函数会将任何合适的字符串转换为数字。我在这里回答了这个问题:https://stackoverflow.com/a/58997070/2464381 但这是所需的功能。

      def to_number(n):
          ''' Convert any number representation to a number 
          This covers: float, decimal, hex, and octal numbers.
          '''
      
          try:
              return int(str(n), 0)
          except:
              try:
                  # python 3 doesn't accept "010" as a valid octal.  You must use the
                  # '0o' prefix
                  return int('0o' + n, 0)
              except:
                  return float(n)
      

      【讨论】:

      • @SergeyVoronezhskiy,3.8.2 和 3.9 仍然无法将“010”识别为八进制(十进制 8)。似乎他们仍然需要 0o 前缀。我确信这是为了避免将 0 填充数字解释为非常不常见的八进制。所以,自从我在 2019 年发布这个答案以来,真的什么都没有改变。
      【解决方案11】:

      在 Python 2.7 中,int('deadbeef',10) 似乎不起作用。

      以下对我有用:

      >>a = int('deadbeef',16)
      >>float(a)
      3735928559.0
      

      【讨论】:

      • 这如何回答这个问题?
      【解决方案12】:

      带有'0x'前缀,你也可以使用eval函数

      例如

      >>a='0xff'
      >>eval(a)
      255
      

      【讨论】:

      • 如果使用 eval,请确保正确完成输入验证。事实上,可能还有更好的方法。不要使用 eval。
      • 至少你应该使用ast.literal_eval
      • 也很慢。有史以来最糟糕的方式。
      猜你喜欢
      • 2021-06-22
      • 1970-01-01
      • 2020-07-18
      • 1970-01-01
      • 2019-07-23
      相关资源
      最近更新 更多