如果使用子进程调用此程序,则从程序的记录器获取消息时出现问题。
以下是使用记录器将消息打印到文件和控制台窗口的程序BooFoo.py:
import logging
LOG_FILENAME = 'example.log'
logging.basicConfig(filename=LOG_FILENAME,level=logging.DEBUG)
logger = logging.getLogger('main')
logger.addHandler(logging.StreamHandler())
print 'print foo'
logger.info('logger boo')
这是程序CallBooFoo.py:
import subprocess
proc = subprocess.Popen(['python BooFoo.py'], bufsize=512, stdin = None,
stdout = subprocess.PIPE, stderr = subprocess.PIPE, shell=True)
proc_out, proc_err = proc.communicate()
print proc_out
“logger boo”没有使用CallBooFoo.py打印。知道如何解决这个问题吗?使用os.system有效,但由于其他一些原因,它不是解决方案。
答案 0 :(得分:3)
logging.StreamHandler
默认写入标准错误,而不是标准输出。您可以使用logging.StreamHandler(sys.stdout)
来更改为标准输出。
您也可以按原样保留代码,并在调用过程中打印proc_err
的值,而不是proc_out
。这将显示子进程的标准错误。
如果您需要将stdout和stderr混合在一起,可以将调用过程更改为:
proc = subprocess.Popen(['python BooFoo.py'], bufsize=512, stdin = None,
stdout = subprocess.PIPE, stderr = subprocess.STDOUT, shell=True)
proc_out, proc_err = proc.communicate()
print proc_out