如何在python2上从txt文件中拆分多行(包含逗号)字符串

时间:2017-04-27 15:15:40

标签: python

我是Pyhton的新人,所以我需要你的帮助

我有这样的文字:

19 , 22.3 ,22.24 , 79 , 40.764767 ,29.932207  
1 , 24.38 ,24.50 , 586 , 40.762291 ,29.919300  
11 , 23.13 ,23.24 , 105 , 40.763786 ,29.929407  
12 , 22.38 ,23.56 , 71 , 40.765610 ,29.941540  
5 , 23.2 ,24.15 , 173 , 40.763805 ,29.929356  

我试图分裂:

array = file.read().split(",")

但结果是这样的

['19 ', ' 22.3 ', '22.24 ', ' 79 ', ' 40.764767 ', '29.932207  \n1 ',
 ' 24.38 ', '24.50 ', ' 586 ', ' 40.762291 ', '29.919300  \n11 ', ' 23.13 ',
'23.24 ', ' 105 ', ' 40.763786 ', '29.929407  \n12 ', ' 22.38 ', '23.56 ', 
' 71 ', ' 40.765610 ', '29.941540  \n5 ', ' 23.2 ', '24.15 ', ' 173 ',
 ' 40.763805 ', '29.929356 \n']

但是我想在没有'\ n'的情况下创建它,因为在拆分操作之后,我必须将字符串返回到int。那我该怎么做呢?

4 个答案:

答案 0 :(得分:4)

import re
x="""19 , 22.3 ,22.24 , 79 , 40.764767 ,29.932207
1 , 24.38 ,24.50 , 586 , 40.762291 ,29.919300
11 , 23.13 ,23.24 , 105 , 40.763786 ,29.929407
12 , 22.38 ,23.56 , 71 , 40.765610 ,29.941540
5 , 23.2 ,24.15 , 173 , 40.763805 ,29.929356  """
print re.split(r" *, *|\n", x)

您可以使用re一次性完成。

输出:['19', '22.3', '22.24', '79', '40.764767', '29.932207', '1', '24.38', '24.50', '586', '40.762291', '29.919300', '11', '23.13', '23.24', '105', '40.763786', '29.929407', '12', '22.38', '23.56', '71', '40.765610', '29.941540', '5', '23.2', '24.15', '173', '40.763805', '29.929356 ']

答案 1 :(得分:0)

这是否有效:

array = [file.read().replace('\n','').split(',')]

答案 2 :(得分:-1)

这应该有效:

array = [line.split(',') for line in file.read().splitlines()

答案 3 :(得分:-1)

您的文本文件每行有六个浮点数。

如果你想让每一行分开:

with open("path/to/file", "rt") as f:
    data = [ [float(v.strip()) for v in l.strip().split(',')] 
            for l in f]

如果你只想要一个包含所有数字的数组(即忽略文件的行结构)

with open("path/to/file", "rt") as f:
    data = [ float(v.strip()) 
             for l in f 
             for v in l.strip().split(',')]