Hex to Base64 conversion in Python

前端 未结 7 1037
一整个雨季
一整个雨季 2021-02-04 03:47

I want to convert a simple HEX string such as 10000000000002ae to Base 64.

The hex string is to be converted to bytes, and the bytes are then encoded to base64 notation,

相关标签:
7条回答
  • 2021-02-04 04:03

    Python 2 has native support for both HEX and base64 encoding:

    encoded = HEX_STRING.decode("hex").encode("base64")
    

    (if you are using Python 3, see Eana Hufwe or Ali's answers instead)

    0 讨论(0)
  • 2021-02-04 04:05

    In case someone is looking for a python3 one-liner (bash):

    python -c "import codecs as c; print(c.encode(c.decode('10000000000002ae', 'hex'), 'base64').decode())"
    
    0 讨论(0)
  • 2021-02-04 04:08

    Python has native support for both HEX and base64 encoding:

    import base64
    
    def main():
        b16 = bytearray('10000000000002ae'.decode('hex'))
        b64 = base64.b64encode(b16)
    
        print b64
    
    0 讨论(0)
  • 2021-02-04 04:09

    In python3, you may use bytes.fromhex to bytes, use base64 package convert bytes to base64

    hex_str = '01'
    encoded_str = base64.b64encode(bytes.fromhex(hex_str)).decode('utf-8')
    decoded_str = base64.b64decode(encoded_str.encode('utf-8')).hex()
    
    0 讨论(0)
  • 2021-02-04 04:10
    from base64 import b64encode, b64decode
    
    # hex -> base64
    s = 'cafebabe'
    b64 = b64encode(bytes.fromhex(s)).decode()
    print('cafebabe in base64:', b64)
    
    # base64 -> hex
    s2 = b64decode(b64.encode()).hex()
    print('yv66vg== in hex is:', s2)
    assert s == s2
    

    This prints:

    cafebabe in base64: yv66vg==
    yv66vg== in hex is: cafebabe
    

    The relevant functions in the documentation, hex to base64:

    • b64encode
    • bytes.fromhex
    • bytes.decode

    Base64 to hex:

    • b64decode
    • str.encode
    • bytes.hex

    I don't understand why many of the other answers are making it so complicated. For example the most upvoted answer as of Aug 26, 2020:

    • There is no need for the codecs module here.
    • The codecs module uses base64.encodebytes(s) under the hood (see reference here), so it converts to multiline MIME base64, so you get a new line after every 76 bytes of output. Unless you are sending it in e-mail, it is most likely not what you want.

    As for specifying 'utf-8' when encoding a string, or decoding bytes: It adds unnecessary noise. Python 3 uses utf-8 encoding for strings by default. It is not a coincidence that the writers of the standard library made the default encoding of the encode/decode methods also utf-8, so that you don't have to needlessly specify the utf-8 encoding over and over again.

    0 讨论(0)
  • 2021-02-04 04:14

    Edit 26 Aug 2020: As suggested by Ali in the comments, using codecs.encode(b, "base64") would result in extra line breaks for MIME syntax. Only use this method if you do want those line breaks formatting.

    For a plain Base64 encoding/decoding, use base64.b64encode and base64.b64decode. See the answer from Ali for details.


    In Python 3, arbitrary encodings including Hex and Base64 has been moved to codecs module. To get a Base64 str from a hex str:

    import codecs
    
    hex = "10000000000002ae"
    b64 = codecs.encode(codecs.decode(hex, 'hex'), 'base64').decode()
    
    0 讨论(0)
提交回复
热议问题