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'