• 字符串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。
    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