本文共 586 字,大约阅读时间需要 1 分钟。
有一个c动态库以在stdout中写入日志条目。我正在使用ctypes库在python应用程序中使用它。python应用程序使用logging库来编写日志条目。
需要做的是捕获共享库的stdout条目,以便使用logging模块写入日志条目。换句话说,我想将c库的stdout条目重定向到logging模块,这样我就可以使用logging使用它的处理程序来写入文件和控制台。
先把stdout设备备份,再把pipe管道设置为stdout,调用相关的程序,这样就可以通过pipe拿到stdout日志信息,最后把stdout设备还原。
# -*- coding: utf-8 -*-import ospipe_out, pipe_in = os.pipe()stdout = os.dup(1)print "stdout log"# 标准输出到文件os.dup2(pipe_in, 1)print "pipe log"# 标准输出还原os.dup2(stdout, 1)print "stdout log2"os.close(pipe_in)r = os.fdopen(pipe_out)# 输出重定向日志print(r.read())r.close()
输出结果,通过pipe读出
参考:
https://www.coder.work/article/837720转载地址:http://jqfli.baihongyu.com/