Ваш код уже извлекает строки группами по 19 строк, поэтому я не уверен, в чем ваша проблема.
Я могу немного подчистить ваше решение, но оно делает то же самое, что и ваш код:
from itertools import izip_longest
# grouping recipe from itertools documentation
def grouper(n, iterable, fillvalue=None):
"Collect data into fixed-length chunks or blocks"
# grouper(3, 'ABCDEFG', 'x') --> ABC DEF Gxx
args = [iter(iterable)] * n
return izip_longest(fillvalue=fillvalue, *args)
def process_chunk(chunk):
"Return sequence of result lines. Chunk must be iterable."
for i, line in enumerate(chunk):
yield 'file-line {1:03d}; chunk-line {0:02d}\n'.format(i, int(line))
yield '----------------------------\n'
Вот некоторый тестовый код, который демонстрирует, что посещается каждая строка:
from StringIO import StringIO
class CtxStringIO(StringIO):
def __enter__(self):
return self
def __exit__(self, *args):
return False
infile = CtxStringIO(''.join('{}\n'.format(i) for i in xrange(19*10)))
outfile = CtxStringIO()
# this should be the main loop of your program.
# just replace infile and outfile with real file objects
with infile as ifp, outfile as ofp:
for chunk in grouper(19, ifp, '\n'):
ofp.writelines(process_chunk(chunk))
# see what was written to the file
print ofp.getvalue()
Этот тестовый пример должен печатать такие строки:
file-line 000; chunk-line 00
file-line 001; chunk-line 01
file-line 002; chunk-line 02
file-line 003; chunk-line 03
file-line 004; chunk-line 04
...
file-line 016; chunk-line 16
file-line 017; chunk-line 17
file-line 018; chunk-line 18
----------------------------
file-line 019; chunk-line 00
file-line 020; chunk-line 01
file-line 021; chunk-line 02
...
file-line 186; chunk-line 15
file-line 187; chunk-line 16
file-line 188; chunk-line 17
file-line 189; chunk-line 18
----------------------------
person
Francis Avila
schedule
29.04.2013
break
? - person Francis Avila   schedule 29.04.2013