【发布时间】:2016-08-24 20:55:22
【问题描述】:
关于检索 FTP 文件并将其写入流(如字符串缓冲区或随后可以迭代的文件)的堆栈溢出有几个答案。
如:Read a file in buffer from FTP python
但是,这些解决方案涉及在开始处理内容之前将整个文件加载到内存或将其下载到磁盘。
我没有足够的内存来缓冲整个文件,并且我无权访问磁盘。这可以通过处理回调函数中的数据来完成,但是我想知道是否可以将 ftp 代码包装 以某种返回迭代器的魔法而不是在我的代码中添加回调。 p>
I.E.而不是:
def get_ftp_data(handle_chunk):
...
ftp.login('uesr', 'password') # authentication required
ftp.retrbinary('RETR etc', handle_chunk)
...
get_ftp_data(do_stuff_to_chunk)
我想要:
for chunk in get_ftp_data():
do_stuff_to_chunk(chunk)
并且(与现有答案不同)我想在迭代之前不将整个 ftp 文件写入磁盘或内存。
【问题讨论】: