如何在Python中读取(或写入)二进制数据?
要读取或写入二进制文件,首先您需要了解 Python 中二进制文件的不同文件模式 -
模式 | 描述 |
---|---|
rb | 打开一个文件以只读二进制格式。文件指针位于文件的开头。这是默认模式。 |
rb+ | 打开一个文件以二进制格式进行读写。文件指针放置在文件的开头。 |
wb | 打开仅以二进制格式写入的文件。如果文件存在则覆盖该文件。如果该文件不存在,则创建一个新文件进行写入。 |
wb+ | 打开一个文件以二进制格式进行写入和读取。如果文件存在,则覆盖现有文件。如果文件不存在,则创建一个新文件进行读写。 |
ab | 打开一个文件以二进制格式追加。如果文件存在,则文件指针位于文件末尾。也就是说,该文件处于追加模式。如果该文件不存在,则会创建一个新文件进行写入。 |
ab+ | 打开文件以二进制格式追加和读取。如果文件存在,则文件指针位于文件末尾。文件以追加模式打开。如果该文件不存在,则会创建一个新文件进行读写。 |
读取二进制文件
假设我们有一个二进制文件。我们可以使用 read() 方法来读取它。首先,我们将使用 open() 方法的 rb 模式打开二进制文件。我们在 D: 驱动器中有以下源文件 -
示例
让我们看看完整的代码
# Open a binary file f = open('D:\PythonLogo.png', 'rb') # Read lines data = f.read() # Display the data print(data)
输出
二进制文件不可读,内容无法识别。实际产量更大。下面我们只展示了一部分。
b'\x89PNG\r\n\x1a\n\x00\x00\x00\rIHDR\x00\x00\x04\xb0\x00\x00\x04\xb0\x08\x06\x00\x00\x00 \xeb!\xb3\xcf\x00\x00\x00\x04gAMA\x00\x00\xb1\x8f\x0b\xfca\x05\x00\x00\x00 cHRM\x00\x00z&\x00\x00\x80\x84\x00\x00\xfa\x00\x00\x00\x80\xe8\x00\x00u0\x00\x00\xea`\x0 0\x00:\x98\x00\x00\x17p\x9c\xbaQ<\x00\x00\x00\x06bKGD\x00\xff\x00\xff\x00\xff\xa0\xbd\xa7\x 93\x00\x00\x00\x07tIME\x07\xe1\x08\n\x07\x16\x07\xc9\xb2\xff\xd3\x00\x00\x80\x00IDATx\xda\ xec\x9dw\xbc]e\x95\xf7\x7f\xcf>\xe7\xa6\x91@\xe8\xc5\x02\xa2\x88\x14q0B\x12\xc0\x99\x00!\x 88(\x02\x9a\x8c\x85"\xea\x80b\xc5\x02\xa1\xf8z\xa78\x8aJ\x13EeF\x1d\xdb\x94\x80@\x08\xea\x a0\x8c\xe0\x0c\x98\x10`\x94\x92\xd0D@,#\x88\xd4\x90r\xef\xd9\xeb\xfd#\x01\x02i\xe7\x9e\xb3 \xcb\xf3\xac\xfd\xfd~>\xef; . . . \xcdn\xd2d\xb1Q\xdf\xfa\xe9\x8d|\x8f\x14\x00\x00\x00\xb4\t\x02\x0b\x00\x00\x00\xe0Q\x98\xa 9\xd0\xd5\xc7\x1c$Izp\xee>\x9a\xd8\xfa\x98\x1d\xffdr\x7f\x153\x8f\xfa\xf8\xa3\xcdQJ\x07\xec\x e5\xc8\xf5X\x95\x96\x1eu\n\xdb\xac\xa4- {\xf9{\xdbe\xf6\xc0#\xfe\xa7\t\xdd\xaf\xed\x9a\xd9\xd1\xf5\xe4\x83\xdawf\xc7w>m\xdb\xbc5- X\xff \xb3\x07\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xd02\xff?\xca\x9f\x86X\x17m\x83=\ x00\x00\x00%tEXtdate:create\x002017-08- 10T07:22:07+00:00u\xea\xe6c\x00\x00\x00%tEXtdate:modify\x002017-08- 10T07:22:07+00:00\x04\xb7^\xdf\x00\x00\x00\x00IEND\xaeB`\x82'
写入二进制文件
open()方法的wb模式用于以写入格式打开文件。
注意 - 二进制文件不可读,内容无法识别
让我们看一下完整的示例。在这里,文件将存储在E盘中,名称为
示例
MyDemoBinary.bin -
# Open a file in binary format for writing f = open("E:\MyDemoBinary.bin","wb") # Elements to be added to the binary file a = [100, 200, 300] # Convert the integer elements to a bytearray myArr = bytearray(a) # The byte representation ius now written to the file f.write(myArr) f.close()
输出
运行文件后,文件在设置的路径即E盘中可见 -
以上是如何在Python中读取(或写入)二进制数据?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

在使用Golang开发过程中,经常会遇到一些错误。其中之一是"undefined:io.ReadAll",这个错误大多数情况下是由于使用了过时的方法导致的。本文将会介绍如何解决这个错误。首先,让我们看一下发生这个错误的原因。在golang1.15版本之前,io包中并没有ReadAll方法。我们在使用这个方法时,编译器会提示“undefined:io.Re

这适用于想要执行手动激活的用户。如果需要帮助,为您执行此操作的工具,然后检查此处。我们可以将手动激活过程分为两部分。1-从现成的批处理文件确保已启用互联网。以管理员身份打开WindowsPowershell,然后输入以下内容按给出命令的顺序列出命令。输入密钥,(替换为密钥从上面的列表中)使用以下命令<key>slmgr/ipk<key>从这里下载通用门票并提取下载的文件。现在在Powershell中输入以下代码(Get-ItemProper

在Go语言中,bytes包是一个用于操作字节类型的包,并且它包含了许多有用的方法,比如Split()方法。不过,在使用Split()方法时,你可能会遇到“undefined:bytes.Split”的错误。这种错误通常是由于Go版本不兼容或缺少必要的依赖库等原因引起的。这篇文章将介绍一些解决这种错误的方法。方法一:升级Go版本如

linux io指的是一种文件操作;在Linux中,文件就是一串二进制流,那么在信息的交换过程中,我们都是对这些流进行数据收发操作,这些操作简称为I/O操作;由于Linux使用的是虚拟内存机制,所以必须通过系统调用请求内核来完成IO动作。

概念fio,又称为FlexibleIOTester,是JensAxboe编写的应用程序。Jens是LinuxKernel中blockIOsubsystem的维护者。FIO是一种用于测试网络文件系统和磁盘性能的工具,常用于验证机型和比较文件系统性能。它能自动将fio命令发送到集群机器列表,并收集小文件的IOPS和大文件的吞吐量数据。rw=[mode]rwmixwrite=30在混合读写的模式下,写占30%moderead顺序读write顺序写readwrite顺序混合读写randwrite随机写r

使用io/ioutil.WriteFile函数将字符串写入文件,并设置文件权限和缩进格式在Go语言中,使用io/ioutil包中的WriteFile函数可以很方便地将字符串写入文件。同时,我们也可以通过设置文件权限和缩进格式来满足不同的需求。下面是一个示例代码,演示了如何使用WriteFile函数写入文件并设置权限和缩进格式:packagemainim

在使用golang进行开发时,我们经常会遇到各种各样的问题和错误提示。其中一个常见的问题就是出现了“undefined:io.TeeReader”错误。这个错误通常会在程序编译时出现,而且有时候可能会让人束手无策。本文将介绍如何解决这个问题,以便让您能够顺利地进行golang的开发工作。首先,让我们看一下这个错误的具体含义是什么。当我们在使用

概念IO流可以初步的理解为数据间的传输,我们将一组数据入:1234567,将他们从hello文件中转入haha文件中,使用程序的方法进行转入的话则需要一个一个的传入,即为一个字节一个字节的传输,我们每次只能传入或读取一个字节,这就是io流的大致流程,io流对任何类型的文件都可以进行读取。如:文本文件,图片,歌曲mp3,视频等等的。因为io流是一个字节一个字节的传入读取的所以我们需要用到byte单字节变量来获取长度。如果获取过多的内容则需要使用对应的数组。io流对应的方法所有io流方法中都需要写入
