热门IT资讯网

python数据类型 ——bytes 和 bytearray

发表于:2024-11-29 作者:热门IT资讯网编辑
编辑最后更新 2024年11月29日,bytes和 bytearraybytes:可以看作是一组二进制数值(0-255) 的 str 序列bytearray :可以看作是一组二进制数值(0-255) 的 list 序列bytes类型字符串

bytes和 bytearray

bytes:可以看作是一组二进制数值(0-255) 的 str 序列
bytearray :可以看作是一组二进制数值(0-255) 的 list 序列

bytes类型

字符串转bytes类型

# 将返回 bytes 类型 b" abc "bs1 = bytes("abc","utf-8")# 可以使用字符的16进制字符表达形式bs2 = bytes('\x61\x62\x63',"utf-8")# 直接对字符进行编码成二进制形式bs2 = "abc".encode()# 16进制字符转为bytes类型b1 = bytes.fromhex("61 62 63")  #  ==>   b"abc"   "61,62"是两位16进制数组合,该值不能超过 7F ,否则无法对应ASCII表中字符b1.hex()                 # ===>  '616263'   ASCII码中abc字符对应的16进制数组成的字符串,上面函数的逆运算# bytes 类型中单个元素可以看做是一个10进制数值类型print( b1[0] )  # ==>  10进制数,97

数值转化为bytes类型
前面已经说过,bytes 对象可以看做是一组二进制数值(0-255)的字符串,所以可以根据数值创建bytes 对象

# 传入数值类型可迭代对象b1 = bytes(range(97,100))               #  ==> b' abc 'b2 = bytes( [97,98,99] )                   #  ==> b' abc 'b3 = bytes( [97] )                             #  ==> b' a '# 直接传入10进制数值对象而不是可迭代对象,将会生成对应数值字节的空bytesb4 = bytes(3)         #  b'\x00\x00\x00'   三个空字符的 bytes # 通过数值转化将8进制,16进制数字 生成bytes对象b5 = bytes( [ int("61",16) ] )    #16进制  == > 10 进制 ==> bytes ==>b"a"b6 = bytes( [ int("61", 8) ] )     # 8进制  == > 10 进制 ==> bytes  ==>b"1"#  也可利用bytes 对象转化为 10 进制 数值num = int.from_bytes(b"abc","big")         # "abc"对应的三个字节拼接在一起作为一个二进制数,并计算为10进制数输出num                    #    ===>   6382179

bytes 对象可以可以理解为字节的 str 类型,序列一旦创建不可变,同时,字符串类型可以使用的方法,基本适用于bytes对象。
例如

m = bytes("abc","utf-8")n = bytearray(" def ","utf-8")bs = m + n             # bytes 类型的拼接,生成新的bytes对象bs                          # ===> b"abcdef" m.append(100)              # ==> 通过 10进制数,添加 b" d ", 单个值使用整型数值进行传入m.extend(b"efg")           # ==> 扩展bytearray对象使用 bytes或bytearray类型的可迭代对象 

其他字符串方法类似于str ,可查看 str 类型使用方法

bytearray类型

bytearray 可以看作是一组数值(0-256)(二进制) 的 list 序列,意味着bytearray 中的单个元素是可变的

ba1 = bytearray(range(97,103))ba1                                  #  bytearay对象,==>  bytearray(b"abcdef" )ba1[0]                              #   ==>  97  (integer)ba1[1 :2]                          #  切片 ==> bytearray(b'bcd')# 赋值,可变bytearrayba[ 4 ] = 122                    #  122整型对应字符"z",   ==> b"e" --> b"z"ba                                    #   bytearray(b"abcdzf" )ba1[1:4] = b"xyz"             #  切片赋值,替换ba1[1:4]的内容, 只有bytes 或bytearray 序列可赋值ba1                                  #  bytearray(b'axyzef')

bytearay 对象类似于 一个字节 的 list 对象,所以可以使用list 的大部分方法,注意的是,list 对象是对字符层面的操作,bytes 和 bytearay 则需要操作的是字节层面的元素,或者整型(因为0-255的整型值可以直接使用二进制形式存入内存的单个字节中,也属于单个字节操作)

进制转化

bytes对象生成时可以根据16进制字符串(无前缀)或者10进制 数值,可以使用以下方法转换各个进制字符

# 内置函数chr(97)      #    ==> "a"ord("a")     #    ==> 97#带前缀 0x format(97,"#x")                                   # ==> '0x61'format(97,"#o")                                   # 8进制字符format(97,"#b")                                   # 2进制字符#不带前缀format(97,"X")                                    # ==> int ==> hex_strformat(97,"o")                                    # ==> int ==> oct_strformat(97,"b")                                    # ==> int ==> bin_str# 3.6+版本使用方法# f'{255:X}' 和 f'{255:#X}'                   ===> " FF "  和 "0xFF"# 无前缀"%x"                                     # ==> 'a'"%o"                                     # ==> '12'# 带前缀                               "%#x"                                     # ==> '0xa'"%#o"                                     # ==> '0o12'
0