1

我正在尝试从本地存储的 .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

有人可以帮我吗?

4

3 回答 3

3

我找到了答案!我没有调用方法 .readlines()

file_content = file_content.readlines()
for lines in file_content[0:]:
     #stuff
于 2013-07-19T08:33:19.117 回答
2

您可以使用lines = open(filepath, 'rb').readlines()获取字符串列表,其中每个字符串是文件中的一行。然后,您可以在任何索引处对列表进行切片,只获取您感兴趣的行,如下所示:wanted_lines = lines[index:]这将为您获取从索引到文件末尾的所有行。

于 2013-07-19T08:34:23.420 回答
0

您可以使用islicefromitertools模块在文件(或任何可迭代的)上创建切片:

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

于 2013-07-19T08:40:15.070 回答