小墨の博客

梦想需要付诸行动,否则只能是梦

Python 内置模块 base64(转载)

base64模块是用来作base64编码解码,常用于小型数据的传输。编码后的数据是一个字符串,其包括a-z、A-Z、0-9、/、+共64个字符,即可用6个字节表示,写出数值就是0-63.故三个字节编码的话就变成了4个字节,如果数据字节数不是3的倍数,就不能精确地划分6位的块,此时需要在原数据后添加1个或2个零值字节,使其字节数为3的倍数,然后在编码后的字符串后添加1个或2个‘=’,表示零值字节,故事实上总共由65个字符组成。下面举几个小例子。

将3个字节的‘Xue’进行base64编码:

将2个字节‘Xu’进行base64编码:

将1个字节‘X’进行base64编码:

base64 模块真正用的上的方法只有8个,分别是encode, decode, encodestring, decodestring, b64encode, b64decode, urlsafe_b64decode, urlsafe_b64encode。他们8个可以两两分为4组,

encode, decode 一组,用来编码和解码文件,也可以 StringIO 里的数据做编解码;

encodestring, decodestring 一组,用来编码和解码字符串;

b64encode, b64decode 一组,用来编码和解码字符串,并且有替换符号字符的功能;

urlsafe_b64encode, urlsafe_b64decode一组,用来对url进行base64编解码。


代码实例

b64encode和b64decode:对字符串操作

import base64

st = 'hello world!'.encode()#默认以utf8编码
res = base64.b64encode(st)
print(res.decode())#默认以utf8解码
res = base64.b64decode(res)
print(res.decode())#默认以utf8解码

aGVsbG8gd29ybGQh

hello world!


编码与解码的处理对象是byte,故对原数据要先编码,使原本的str类型变成byte,解码后直接输出来的是byte对象,故要解码成str对象。


encode和code:对文件操作,有两个参数,一个是input,一个是output。

import base64
import io

st = "hello world!"
f = io.StringIO()  # 创建文件
out1 = io.StringIO()
out2 = io.StringIO()
f.write(st)
f.seek(0)
base64.encode(f, out1)
print(out1.getvalue())
out1.seek(0)
base64.decode(out1, out2)
print(out2.getvalue())



来源:https://www.cnblogs.com/longwhite/p/10397707.html

张小弟之家

本文链接:
文章标题:

本站文章除注明转载/出处外,均为原创,若要转载请务必注明出处。转载后请将转载链接通过邮件告知我站,谢谢合作。本站邮箱:admin@only4.work

尊重他人劳动成果,共创和谐网络环境。点击版权声明查看本站相关条款。

    发表评论:

    搜索
    本文二维码
    标签列表
    站点信息
    • 文章总数:508
    • 页面总数:20
    • 分类总数:92
    • 标签总数:208
    • 评论总数:61
    • 浏览总数:225323

    | | |
    | |  Z-Blog PHP