python - 用Python读取FTP文件内容并同时用于Pandas和直接使用

标签 python python-3.x pandas ftp ftplib

我正在尝试从内存中的 FTP 服务器下载文件,将其转换为数据帧,但也将其作为字节返回。代码如下:

import io
import pandas as pd
from ftplib import FTP

ftp_connection.cwd(ftp_folder)
download_file = io.BytesIO()
ftp_connection.retrbinary('RETR ' + str(file_name), download_file.write)
download_file.seek(0)
file_to_process = pd.read_csv(download_file, engine='python')

在 Stack Overflow 上搜索后,建议只读取 io 流:

download_file.read()
ValueError: I/O operation on closed file.

不确定下一步要尝试什么,而不是将文件写入某处并以字节形式再次读取。

最佳答案

read_csv 可能会关闭"file"。因此,在调用 read_csv 之前请先阅读它:

download_file.seek(0)
contents = download_file.read()
download_file.seek(0)
file_to_process = pd.read_csv(download_file, engine='python')

关于python - 用Python读取FTP文件内容并同时用于Pandas和直接使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58320638/

相关文章:

python - 如何从列表列表的列表转换为 pandas DataFrame

python - 带有 OAuth 和 Python 的 Gmail API - AccessTokenRefreshError : invalid_grant

python - 是否允许在抽象类中使用用户定义的装饰器?或者说,应该继承后使用吗?

python - 如何在numpy中返回图像中区域的坐标及其尺寸?

python - 嵌套字典理解以避免空值

python-3.x - 如何在 python 中正确模拟 gcp 客户端库调用

python - DJANGO:表单中缺少空白选择选项

python - Python 3.7 数据类中的类继承

python - 引发错误后如何在数据框中标记损坏的数据

python - Pandas 数据框的递归转置