2015-05-06 126 views
1

我有一个文本文件,其中包含我希望打开的文件的文件路径。访问保存在.txt文件中的文件路径。 (Python)

文本文件看起来像这样:

28.2 -1.0 46 14 10 .\temp_109.17621\voltage_28.200\power_-1.txt 
28.2 -2.0 46 16 10 .\temp_109.17621\voltage_28.200\power_-2.txt 

...

我想在这个文件路径打开文件。

第一步是从文本文件中加载每个文件路径。

我已经试过这一点使用:

path = np.loadtxt('NonLorentzianData.txt',usecols=[5],dtype='S16') 

产生一个path[1],看起来像:

.\\temp_109.17621 ...

而不是整个文件路径。

我使用了错误的dtype或者这不可能与loadtxt

+0

loadtxt负载字面上的文件中包含的启发。它不明白该列是一个文件路径。 – nneonneo

+0

是的。就这些。 – 8765674

+0

@ 8765674全部都是正确的,你使用S16作为一个类型并返回了长度为16的字符串(\\是一个字符)。根据[this](http://stackoverflow.com/questions/20121949/python-numpy-loadtxt-with-varied-string-entries-but-know-line-format)尝试使用'np.genfromtxt'和' dtype = None'或者正确调整字符串的长度 – Reishin

回答

1

您可以使用S16作为一种类型,并得到.\\temp_109.17621作为结果(\\转义\),并返回字符串长度= 16。

尝试使用np.genfromtxtdtype=None或适当调整dtype='S45'(你的情况)

通过post

1

如果更改数据类型np.str_它会工作:

path = np.loadtxt('NonLorentzianData.txt',usecols=[5],dtype=np.str_) 

print(path[1]) 
.\temp_109.17621\voltage_28.200\power_-2.txt 

或者使用dtype=("S44")也将工作,这是你的最长的两条路径的长度。 您正在指定一个16个字符的字符串因此您只能得到的前16个字符

In [17]: s = ".\\temp_109.17621" 

In [18]: len(s) 
Out[18]: 16 

# 43 character string 
In [26]: path = np.loadtxt('words.txt',usecols=[5],dtype=("S43"))  
In [27]: path[1] 
Out[27]: '.\\temp_109.17621\\voltage_28.200\\power_-2.tx'  
In [28]: len(path[1]) 
Out[28]: 43  
# 38 character string 
In [29]: path = np.loadtxt('words.txt',usecols=[5],dtype=("S38"))  
In [30]: path[1] 
Out[30]: '.\\temp_109.17621\\voltage_28.200\\power_'  
In [31]: len(path[1]) 
Out[31]: 38 
In [32]: path = np.loadtxt('words.txt',usecols=[5],dtype=np.str_) 
In [33]: path[1] 
Out[33]: '.\\temp_109.17621\\voltage_28.200\\power_-2.txt' 

如果你看一下docs你会看到什么每一个D型功能以及如何使用它们。

如果你只是希望所有的文件路径,你也可以使用csv.reader

import csv 
with open("NonLorentzianData.txt") as f: 
    reader = csv.reader(f,delimiter=" ") 
    for row in reader: 
     with open(row[-1]) as f: 
      ..... 
+0

不是从路径文件加载的情况,根据'。\\ temp_109.17621 ...''斜线很好地逃脱了 – Reishin