我有以下代码:
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行... 我不知道该怎么做。
答案 0 :(得分:3)
好吧,如果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 += 1
答案 1 :(得分:3)
未测试:
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()
它具有处理任意大文件的优点,因为它只存储它当前正在处理的数据而不是命令的整个输出。