【Python】bytes数据类型

本文详细介绍了Python中的bytes数据类型,包括通过bytes()函数创建bytes对象,以及如何使用encode()和decode()方法在bytes和str类型之间进行转换。在处理二进制文件时,使用file.read()会得到bytes类型数据,可能包含不必要的字符,通过decode()可以将其转换为可读的str格式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

bytes函数

python中用file.read()函数读取二进制文件时,得到的数据是<class ‘bytes’>类型;如下是一个二进制文件,每行4个字节,共32位;
在这里插入图片描述
用file.read()函数读取,后面每次读8个字节输出结果:均为bytes类型(对于前20个字节,我存储的是当前日期)
在这里插入图片描述
对于前20个字节,我存储的是当前日期,读取的结果是

b'1970-01-01 00:10:46\x00

这显然出现了我们不希望出现的字符,比如开头的b,结尾处的\x00,因此我们要对该数据进行处理

bytes()函数

bytes 函数返回一个新的 bytes 对象,该对象是一个 0 <= x < 256 区间内的整数不可变序列。

语法

以下是 bytes 的语法:

class bytes([source[, encoding[, errors]]])
参数
如果 source 为整数,则返回一个长度为 source 的初始化数组;
如果 source 为字符串,则按照指定的 encoding 将字符串转换为字节序列;
如果 source 为可迭代类型,则元素必须为[0 ,255] 中的整数;
如果 source 为与 buffer 接口一致的对象,则此对象也可以被用于初始化 bytearray。
如果没有输入任何参数,默认就是初始化数组为0个元素。
返回值
返回一个新的 bytes 对象。
举个栗子

在这里插入图片描述
在 Python 中,有 2 种常用的字符串类型,分别为 str 和 bytes 类型,其中 str 用来表示 Unicode 字符,bytes 用来表示二进制数据。str 类型和 bytes 类型之间就需要使用 encode() 和 decode() 方法进行转换。

encode()方法

encode() 方法为字符串类型(str)提供的方法,用于将 str 类型转换成 bytes 类型,这个过程也称为“编码”。

语法格式:
str.encode([encoding="utf-8"][,errors="strict"])
举个栗子

在这里插入图片描述

decode()方法

和 encode() 方法正好相反,decode() 方法用于将 bytes 类型的二进制数据转换为 str 类型,这个过程也称为“解码”。上面出现的日期问题,利用decode()对其进行解码就可以转换成str格式,不会出现无关字符

语法格式
bytes.decode([encoding="utf-8"][,errors="strict"])
举个栗子

在这里插入图片描述

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值