问题描述
大家好,我的问题是这样的:我在调用一个函数solve()的过程中,这个函数会不停的向console打印值,但是这个函数不是我写的,我只能从外部看到这些打印出来的语句而无法获得他的值。现在的问题是,这个solve函数可能会执行3分钟甚至更长,在这期间我需要给软件的用户反馈信息,比如在tk编程里面把这些执行过程中的信息输出到一个textarea控件里,我该如何做?不然用户一定以为程序死掉了..很关键的一个问题是,执行到solve这个函数以后程序就停在这里了,即使我能获得print语句输出的值,也要等solve执行完再一股脑放到textarea里,这不是我想要的效果。各位高手,我该怎么做?给出点思路也好,谢谢!! [size=large]
解决方案
因为print是输出到sys.out里面, 所以主要思路就是替换标准的输出, 写了一个例子供你参考:# coding: utf-8class TextArea(object): def __init__(self): self.buffer = [] def write(self, *args, **kwargs): self.buffer.append(args)import sysstdout = sys.stdoutsys.stdout = TextArea()# print to TextAreaprint "testA"print "testB"print "testC"text_area, sys.stdout = sys.stdout, stdout# print to consoleprint text_area.buffer
时间: 2024-12-04 00:26:07