繁体   English   中英

熊猫:如何加载包含多个txt文件的zip文件?

[英]Pandas: how to load a zip file containing multiple txt files?

我的路径中存储了很多zip文件

  • mypath/data1.zip
  • mypath/data2.zip
  • 等等

每个zip文件包含三个不同的txt文件。 例如,在data1.zip有:

  • data1_a.txt
  • data1_b.txt
  • data1_c.txt

我需要加载datai_c.txt从每个压缩文件(即data1_c.txtdata2_c.txtdata3_c.txt等),并把它们连接成一个数据帧。

不幸的是我无法使用read_csv这样做,因为它只适用于单个压缩文件。

有什么想法怎么做? 谢谢!

因此,您需要一些其他代码才能进入zip文件。 下面是O'Reilly的Python Cookbook的修改代码

import zipfile
import pandas as pd
## make up some data for example
x = pd.DataFrame({"A": [1, 2], "B": [3, 4]}) 
x.to_csv('a.txt', sep="|", index=False) 
(x * 2).to_csv('b.txt', sep="|", index=False)

with zipfile.ZipFile('zipfile.zip', 'w') as myzip:
    myzip.write('a.txt')
    myzip.write('b.txt')
    for filename in z.namelist( ): print 'File:', filename,
         insideDF = pd.read_csv(StringIO(z.read(filename)))
         df = pd.concat([df, insideDF])
print df

您希望使用patool库,如下所示:

import patool
import pandas as pd
compression = zipfile.ZIP_DEFLATED
patoolib.extract_archive('mypath/data1.zip', outdir='mypath', interactive=False, verbosity=-1)

存储在一个文件eachtxt DataFrame使用read_csv如:DF = pd.read_csv( 'mypath中/ data1_a')

然后使用pd.concat以您想要的任何方式连接数据帧。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM