读取二进制文件并遍历每个字节

问题描述

f = open("myfile", "rb")
try:
    byte = f.read(1)
    while byte != "":
        # Do stuff with byte.
        byte = f.read(1)
finally:
    f.close()

with open("myfile", "rb") as f:
    byte = f.read(1)
    while byte != "":
        # Do stuff with byte.
        byte = f.read(1)

请注意,with 语句在低于 2.5 的 Python 版本中不可用。要在 v 2.5 中使用它,您需要导入它:

from __future__ import with_statement

在 2.6 中,这不是必需的。

在 Python 3 中,它有点不同。我们将不再以字节模式从流中获取原始字符,而是字节对象,因此我们需要更改条件:

with open("myfile", "rb") as f:
    byte = f.read(1)
    while byte != b"":
        # Do stuff with byte.
        byte = f.read(1)

或者正如本霍伊特所说,跳过不相等并利用b""评估为假的事实。这使得代码在 2.6 和 3.x 之间兼容,无需任何更改。如果您从字节模式转到文本或相反,它还可以使您免于更改条件。

with open("myfile", "rb") as f:
    byte = f.read(1)
    while byte:
        # Do stuff with byte.
        byte = f.read(1)

从现在开始,感谢 := 运算符,上面的代码可以用更短的方式编写。

with open("myfile", "rb") as f:
    while (byte := f.read(1)):
        # Do stuff with byte.

解决方法

在 Python 中,如何读取二进制文件并遍历该文件的每个字节?