python数据l类型 ——bytes 和 bytearray
bytes和 bytearray
bytes:可以看作是一组数值(0-256)(二进制) 的 str 序列 bytes类型字符串转bytes类型 # 将返回 bytes 类型 b" abc " bs1 = bytes("abc","utf-8") # 可以使用字符的16进制字符表达形式 bs2 = bytes(‘x61x62x63‘,"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类型 # 传入数值类型可迭代对象 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‘x00x00x00‘ 三个空字符的 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" 其他字符串方法类似于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的整型值可以直接使用二进制形式存入内存的单个字节中,也属于单个字节操作) m.append(100) # ==> 通过 10进制数,添加 b" d ", 单个值使用整型数值进行传入 m.extend(b"efg") # ==> 扩展bytearray对象使用 bytes或bytearray类型的可迭代对象 10进制,8进制,16进制字符转化 进制转化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‘ (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |