python⼆进制⽂件读写⽂件_Python读写⽂件的⼆进制数据概述
Python 读写⽂件的⼆进制数据⽐ C/C++ 语⾔复杂得多。主要差别在于需要进⾏ bytes 类型和其它基础数据类型(⽐如 int/float)的转换。
转换⼯具在⼀般情况下都是使⽤ struct 库。
读出数据
在 open 函数中使⽤ rb 作为 mode 打开⽂件,再⽤ struct.unpack 函数解析 bytes 数据。
具体可以参考 open 函数和 stuct.unpack 函数的说明。
数据⽂件中⼆进制数据如下图所⽰:
import struct
# rb 表⽰以⼆进制形式打开⽂件
with open(r"D:\temp\test.raw", mode="rb") as f:
# 移⾄指定字节位置
f.seek(3)
# 读⼊ 16 个字节
python怎么读取文件中的数据
a = f.read(16)
# 打印 a 类型 bytes
print(type(a))
# 打印 a 内字节数⽬
print(len(a))
# 打印 a 内数据,以 16 进制数显⽰
print(a)
# 16 个字节解析为 4 个 unsigned short 数据和 2 个 unsigned int 数据,字节排序为⼩端,返回元组
val_tuple = struct.unpack("<4H2I", a) # 如果解析 1 个数据,则应当读取与数据存储空间⼤⼩⼀致的字节数⽬,unpack 仍返回元组
print(val_tuple)
# 将元组转为 list
val_list = list(val_tuple)
print(val_list)
16
b'\x00\x80\x02\x00\x00\xe0\x01\x00\x00\x00\xb0\x04\x00\xf8\x12\xf1'
(32768, 2, 57344, 1, 78643200, 4044552192)
[32768, 2, 57344, 1, 78643200, 4044552192]
另⼀种仅可⽤于整数的单个数据转换⽅式是使⽤ int.from_bytes 函数。
# rb 表⽰以⼆进制形式打开⽂件
with open(r"D:\temp\test.raw", "rb") as f:
# 读⼊ 4 个字节
a = f.read(4)
# ⼩端有符号整数
b = int.from_bytes(a, byteorder='little', signed=True)
print(b)
print(type(b))
16
写⼊数据
在 open 函数中使⽤ wb 或者 ab 作为 mode 打开⽂件,再⽤ struct.pack 函数将数据转化为 bytes 数据后写⼊。具体可以参考 open 函数和 stuct.unpack 函数的说明。
import struct
# rb 表⽰以⼆进制形式打开⽂件
with open(r"D:\temp\test_wr.raw", "wb") as f:
val_list = [32768, 2, 57344, 1, 78643200, 4044552192]
a = struct.pack("<4H2I", *val_list) # 注意根据 pack 函数定义,必须⽤ * 对 list 解包
print(a)
f.write(a)
b'\x00\x80\x02\x00\x00\xe0\x01\x00\x00\x00\xb0\x04\x00\xf8\x12\xf1'
完成写⼊后的⽂件内数据如下图所⽰:
另⼀种写⼊单个整数的数据转换⽅式是使⽤ _bytes 函数:
import struct
# ⽤ ab 进⾏追加写⼊
with open(r"D:\temp\test_wr.raw", "ab") as f:
val = 16
# 转化为 2 字节⼤端元符号整数
a = _bytes(length=2, byteorder='big', signed=False) # 写⼊⽂件
f.write(a)
完成写⼊后的⽂件内数据如下图所⽰:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。