如何解决读取二进制文件并遍历每个字节
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 中,如何读取二进制文件并遍历该文件的每个字节?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。