小编Win*_*ton的帖子

将 ZipFile 从 URL 读取到 StringIO 中并使用 panda.read_csv 进行解析

ZipFile我正在尝试从 URL读取数据并通过使用解析 as csvStringIO内的数据ZipFilepandas.read_csv

r = req.get("http://seanlahman.com/files/database/lahman-csv_2014-02-14.zip").content
file = ZipFile(StringIO(r))
salaries_csv = file.open("Salaries.csv")
salaries = pd.read_csv(salaries_csv)
Run Code Online (Sandbox Code Playgroud)

最后一行给了我一个错误:

CParserError: Error tokenizing data. C error: Calling read(nbytes) on source failed. Try engine='python'.
Run Code Online (Sandbox Code Playgroud)

但是如果我尝试使用

salaries = pd.read_csv(file.open("Salaries.csv"))
Run Code Online (Sandbox Code Playgroud)

有用。

所以我想知道我在这里错过了什么。

file.open应该返回一个ZipExtFile对象,并且由于 read_csv 仅接受字符串或文件句柄/StringIO输入,为什么最后一行可以工作?

python stringio pandas python-zipfile

5
推荐指数
2
解决办法
6159
查看次数

标签 统计

pandas ×1

python ×1

python-zipfile ×1

stringio ×1