字符串str二进制bytes编码解码和长度
发布时间:2021-03-03 01:07:52
作者:ynkulusi
字符串在python内部的表示是unicode编码,也可以说现在的内存是unicode编码格式,硬盘是utf-8。
平常的数据操作都是先把数据读取到内存中,所以内存中都是unicode编码格式。所以我们平常在做编码转换时候,通常用unicode作为中间编码。
先将其他编码的字符串解码(decode)成unicode,再从unicode编码(encode)成另一种编码格式。
decode的作用是将二进制数据解码成unicode编码,如str1.decode('utf-8'),表示将utf-8的编码字符串解码成unicode编码。
简单的来说:decode就是把二进制数据(bytes)转化成人看的懂得英文或者汉字(decode用的比较多)
encode的作用是将unicode编码的字符串编码成二进制数据,如str2.encode('utf-8'),表示将unicode编码的字符串编码成utf-8。
平常的数据操作都是先把数据读取到内存中,所以内存中都是unicode编码格式。所以我们平常在做编码转换时候,通常用unicode作为中间编码。
先将其他编码的字符串解码(decode)成unicode,再从unicode编码(encode)成另一种编码格式。
decode的作用是将二进制数据解码成unicode编码,如str1.decode('utf-8'),表示将utf-8的编码字符串解码成unicode编码。
简单的来说:decode就是把二进制数据(bytes)转化成人看的懂得英文或者汉字(decode用的比较多)
encode的作用是将unicode编码的字符串编码成二进制数据,如str2.encode('utf-8'),表示将unicode编码的字符串编码成utf-8。
print(len("中".encode('utf-8')))
3
print(len("\n".encode('utf-8')))
1
print(len("中".encode('gbk')))
2
print(len("\n".encode('gbk')))
1
print(len("\n\t".encode('utf-8')))
2
print(len("567".encode('utf-8')))
3
print(len("abc".encode('utf-8')))
3
print(len("abc".encode('gbk')))
3
print(len("567".encode('gbk')))
3
print("中".encode('utf-8'))
b'\xe4\xb8\xad'
print("中".encode('gbk'))
b'\xd6\xd0'
print("567".encode('utf-8'))
b'567'
print("abc".encode('utf-8'))
b'abc'
print("abc".encode('gbk'))
b'abc'
print("\n".encode('gbk'))
b'\n'
print("\n".encode('utf-8'))
b'\n'
print("中".encode('utf-8').decode())
中
print("中".encode('utf-8').decode('utf-8'))
中
print("中".encode('gbk').decode('gbk'))
中
print("中".encode().decode())
中
分类:python
评论数:0
阅读数:868