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进制数值对象而不是可迭代对象,将会生成对应数值字节的空bytes
b4 = 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')

# 赋值,可变bytearray
ba[ 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_str
format(97,"o")                                    # ==> int ==> oct_str
format(97,"b")                                    # ==> int ==> bin_str

# 3.6+版本使用方法
# f'{255:X}' 和 f'{255:#X}'                   ===> " FF "  和 "0xFF"

# 无前缀
"%x"%10                                     # ==> 'a'
"%o"%10                                     # ==> '12'
# 带前缀                               
"%#x"%10                                     # ==> '0xa'
"%#o"%10                                     # ==> '0o12'