本文介紹了迭代二進制文件的慣用方法是什么?的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
使用文本文件,我可以這樣寫:
With a text file, I can write this:
with open(path, 'r') as file:
for line in file:
# handle the line
這等價于:
with open(path, 'r') as file:
for line in iter(file.readline, ''):
# handle the line
這個成語記錄在 PEP 234 但我沒有找到二進制文件的類似習語.
This idiom is documented in PEP 234 but I have failed to locate a similar idiom for binary files.
使用二進制文件,我可以這樣寫:
With a binary file, I can write this:
with open(path, 'rb') as file:
while True:
chunk = file.read(1024 * 64)
if not chunk:
break
# handle the chunk
我嘗試過與文本文件相同的習語:
I have tried the same idiom that with a text file:
def make_read(file, size):
def read():
return file.read(size)
return read
with open(path, 'rb') as file:
for chunk in iter(make_read(file, 1024 * 64), b''):
# handle the chunk
這是在 Python 中迭代二進制文件的慣用方式嗎?
Is it the idiomatic way to iterate over a binary file in Python?
推薦答案
我不知道有什么內置的方法可以做到這一點,但是一個包裝函數很容易寫:
I don't know of any built-in way to do this, but a wrapper function is easy enough to write:
def read_in_chunks(infile, chunk_size=1024*64):
while True:
chunk = infile.read(chunk_size)
if chunk:
yield chunk
else:
# The chunk was empty, which means we're at the end
# of the file
return
然后在交互式提示處:
>>> from chunks import read_in_chunks
>>> infile = open('quicklisp.lisp')
>>> for chunk in read_in_chunks(infile):
... print chunk
...
<contents of quicklisp.lisp in chunks>
當然,您可以輕松地將其調整為使用 with 塊:
Of course, you can easily adapt this to use a with block:
with open('quicklisp.lisp') as infile:
for chunk in read_in_chunks(infile):
print chunk
你可以像這樣去掉 if 語句.
And you can eliminate the if statement like this.
def read_in_chunks(infile, chunk_size=1024*64):
chunk = infile.read(chunk_size)
while chunk:
yield chunk
chunk = infile.read(chunk_size)
這篇關于迭代二進制文件的慣用方法是什么?的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!
【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!