Python - base64 模块 - 进阶之路 - Day06

简介

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组:

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

2. encodestring,decodestring一组,专门用来编码和解码字符串; 

3. b64encode和b64decode一组,用来编码和解码字符串,并且有一个替换符号字符的功能;4. urlsafe_b64encode和urlsafe_b64decode一组,这个就是用来专门对url进行base64编解码的。

代码示例

import base64


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

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

 运行结果:

aGVsbG8gd29ybGQh
hello world!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值