[英]Python — Reading lines from file and split it
我正在尝试从本地存储的.txt文件中拆分行。 我做了一个for循环,但是我想在数组的特定索引上开始循环。 例如:
file_content = open('files/filefinal1_test.txt')
counter = 0
total_lines = 0
global l
index = 0 if l == "" else file_content.index(l)
for line in file_content[index:]:
l = line
array_line =line.split('", "')
array_line[0] = array_line[0].replace('"', '')
array_line[1] = array_line[1].replace('"', '')
array_line[2] = array_line[2].replace('"', '')
array_line[3] = array_line[3].replace('"', '')
if (send_req(papi, array_line) == 1):
counter = counter + 1
total_lines = total_lines + 1
这给我以下错误:file_content [index:]有什么方法可以从file_content的特定行开始循环吗?
事实是下面的代码可以工作并循环数组:
for line in file_content:
l = line
array_line =line.split('", "')
array_line[0] = array_line[0].replace('"', '')
array_line[1] = array_line[1].replace('"', '')
array_line[2] = array_line[2].replace('"', '')
array_line[3] = array_line[3].replace('"', '')
if (send_req(papi, array_line) == 1):
counter = counter + 1
total_lines = total_lines + 1
有人可以帮我吗?
我已经找到答案了! 我没有调用方法.readlines()
file_content = file_content.readlines()
for lines in file_content[0:]:
#stuff
您可以使用lines = open(filepath, 'rb').readlines()
来获取字符串列表,其中每个字符串都是文件中的一行。 然后,您可以像这样对列表进行切片:只希望获取感兴趣的行,如下所示: wanted_lines = lines[index:]
这将使您获得从索引到文件末尾的所有行。
您可以使用itertools
模块中的islice
在文件(或任何可迭代的文件)上创建切片:
import itertools
with open('file') as f:
for line in itertools.islice(f, 3, 5): # 3 and 5 are the start and stop points
print line
有关更多信息,请参见http://docs.python.org/2/library/itertools.html#itertools.islice
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.