python bytearray拼接_python数据类型 ——bytes 和 bytearray

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'

你可能感兴趣的:(python,bytearray拼接)