我有以下代码:
def cmds(cmd):
cmd= Popen(cmd, shell=True, stdout=PIPE)
lines = command.stdout.read().splitlines()我有一个输出行的命令,如下所示:
2011/03/30-201
CLIENT 3
Failed
23:17
0.0000
2011/03/31-3
CLIENT 2
Completed
00:47
1.0019我想读取一个块的前3行,然后是下一块的3行,然后是更多的3行…我确实不知道该怎么做。
发布于 2011-03-31 23:45:41
未经测试:
def cmds(cmd):
infile = Popen(cmd, shell=True, stdout=PIPE).stdout
print infile.readline()
print infile.readline()
print infile.readline()
while True:
line = infile.readline()
if not line:
break
if line == '\n':
print infile.readline()
print infile.readline()
print infile.readline()这样做的好处是可以处理任意大的文件,因为它只存储当前正在处理的数据,而不是命令的全部输出。
发布于 2011-03-31 23:45:32
那么,如果lines = command.stdout.read().splitlines()生成一个如下所示的行列表:
['2011/03/30-201', 'CLIENT 3', 'Failed', '23:17', '0.0000', '', '2011/03/31-3', 'CLIENT 2', 'Completed', '00:47', '1.0019']您可以遍历它并打印,直到遇到一个空白条目,然后重置计数器。这不是很优雅,但这是最天真的方式:
lines = command.stdout.read().splitlines()
i = 0
for line in lines:
if line != '':
if i < 3:
print(line)
else:
i = 0
i += 1https://stackoverflow.com/questions/5502454
复制相似问题