python字符串 decode 和 encode

 

# str encode 后返回bytes,byts decode后返回str
a = '你好'
a1 = a.encode('utf-8')  # b'\xe4\xbd\xa0\xe5\xa5\xbd'
a2 = a.encode('gbk')  # b'\xc4\xe3\xba\xc3'
a1.decode('utf-8')    # 你好
a2.decode('gbk')      # 你好

a.encode('ascii')# 出错
#就是那个常见的UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-1: ordinal not in range(128)

 有时候我们得到的文件是以某种编码encode过的,当然也要用对应的编码decode,如果用了错误的编码decode,要么想上面那样编码不在那种编码表中,要么乱码,因为编码格式不一样嘛,要么还是报错,你会得到类似UnicodeDecodeError: 'utf-8' codec can't decode byte 0xc4 in position 0: invalid continuation byte 的错误

 



 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值