繁体   English   中英

如何将几个文件读入python代码并循环遍历它们?

[英]how to read several files into a python code and loop over them?

我正在用python编码,并编写了一个代码,该代码基本上读取一个文件,并从文件中获取一些信息,然后进行一些计算,然后将答案输出到一个新文件中。 现在,我尝试进行概括,以便通过从列出文件的文件中读取文件名来遍历许多文件(因为我需要浏览文件目录)。 但是,我收到此错误消息IOError:[Errno套接字错误] [Errno -2]名称或服务未知

我以为是因为我现在正在尝试系统地为几个文件运行我的代码,因此这是我要做的一些代码:

f = open('//disk2/ps1/cech/CFHTLenS/cluster_catalogues/field_list')
fields = f.readlines()
f.close()
for W in fields:

    file = open('//disk2/ps1/cech/CFHTLenS/cluster_catalogues/clusters_%s_info.cat' %W)
    data = np.loadtxt(file)
    file.close()


    sig_cl = data[:,3].copy()

    m200 = 10**(0.124 * sig_cl + 12.493)
    np.savetxt('//disk2/ps1/bertbert/z_ref_%s.cat'%W,m200)

我不确定为什么您会从文件处理例程中收到套接字错误,但是最明显的问题是W在结尾处会有一个行尾字符,这很可能会引起问题。

尝试:

W = W.strip()

作为for循环的第一行。

在将其添加到要打开的文件名之前,这将从W删除所有前导和尾随空格。

为了循环遍历任意文件集,模块fileinput可以为您提供帮助。 它设置了一个不错的命令行界面,您可以在其中指定一组文件并轻松地遍历它们。

暂无
暂无

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

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