【问题标题】:python encode()蟒蛇编码()
【发布时间】:2012-11-06 07:40:10
【问题描述】:

十六进制编解码器是否已从 python 3.3 中排除?当我写代码时

>>> s="Hallo"
>>> s.encode('hex')
Traceback (most recent call last):
  File "<pyshell#24>", line 1, in <module>
    s.encode('hex')
LookupError: unknown encoding: hex

这是什么意思?我知道 binascii.hexlify() 但仍然 .encode() 方法很好! 有什么建议吗?

【问题讨论】:

  • 所以,缺少“十六进制”代码!有没有办法添加那个编解码器或方法,你的链接上有两个文件,那是做什么的?
  • 要将数字转换为十六进制,您仍然可以使用hex(n)

标签: python-3.x hex encode


【解决方案1】:

不,用encode() hexlify 不好。

您使用hex 编解码器的方式在Python 2 中有效,因为您可以在Python 2 中对8 位字符串调用encode(),即您可以对已经编码的内容进行编码。那没有意义。 encode() 用于将 Unicode 字符串编码为 8 位字符串,而不是用于将 8 位字符串编码为 8 位字符串。

在 Python 3 中,您不能再在 8 位字符串上调用 encode(),因此 hex 编解码器变得毫无意义并被删除。

虽然理论上你可以有一个hex 编解码器并像这样使用它:

>>> import codecs
>>> hexlify = codecs.getencoder('hex')
>>> hexlify(b'Blaah')[0]
b'426c616168'

使用 binascii 更容易更好:

>>> import binascii
>>> binascii.hexlify(b'Blaah')
b'426c616168'

【讨论】:

  • binascii.hexlify() 需要缓冲接口,对吧?那么,有人可以解释一下如何在缓冲区接口上执行格式化吗?
  • @iMagur:抱歉,我忘了编写 Python 3 代码,因为我是在 Python 2 中编写的(因为 hex_codec 在 Python 3 中不存在)。现在已解决此问题。上面的 binascii 代码在 Python 3 中工作,并向您展示了如何做到这一点。在 Python 3 中,字符串是 Unicode,所以不能直接十六进制,需要先编码为bytes
  • 这很好,因为坦率地说,那里有很多 8 位使用。特别是在 ('ascii') 、 ('IBM500')、 ('IBM037') 之间。真正需要的是一些“OD”风格的字符串十六进制方法。选择 Python 是为了减少工作量,这些东西使所需的代码加倍。是的,我知道 IBM500 是 unicode ......
【解决方案2】:

这与上面的答案相同,但我对其进行了修改,使其适用于 python 3。

import binascii
from Crypto.Cipher import AES
from Crypto import Random

def encrypt(passwrd, message):
    msglist = []
    key = bytes(passwrd, "utf-8")
    iv = Random.new().read(AES.block_size)
    cipher = AES.new(key, AES.MODE_CFB, iv)
    msg = iv + cipher.encrypt(bytes(message, "utf-8"))
    msg = binascii.hexlify(msg)
    for letter in str(msg):
        msglist.append(letter)
    msglist.remove("b")
    msglist.remove("'")
    msglist.remove("'")
    for letter in msglist:
        print(letter, end="")
    print("")

def decrypt(passwrd, message):
    msglist = []
    key = bytes(passwrd, "utf-8")
    iv = Random.new().read(AES.block_size)
    cipher = AES.new(key, AES.MODE_CFB, iv)
    msg = cipher.decrypt(binascii.unhexlify(bytes(message, "utf-8")))[len(iv):]
    for letter in str(msg):
        msglist.append(letter)
    msglist.remove("b")
    msglist.remove("'")
    msglist.remove("'")
    for letter in msglist:
        print(letter, end="")
    print("")

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-02-03
    • 2011-01-29
    • 2010-10-27
    • 2010-10-21
    • 2016-05-28
    • 2014-08-01
    • 2021-06-28
    相关资源
    最近更新 更多