python处理ctype模块的输出日志

背景

有一个c动态库以在stdout中写入日志条目。我正在使用ctypes库在python应用程序中使用它。python应用程序使用logging库来编写日志条目。
需要做的是捕获共享库的stdout条目,以便使用logging模块写入日志条目。换句话说,我想将c库的stdout条目重定向到logging模块,这样我就可以使用logging使用它的处理程序来写入文件和控制台。

实现

先把stdout设备备份,再把pipe管道设置为stdout,调用相关的程序,这样就可以通过pipe拿到stdout日志信息,最后把stdout设备还原。

# -*- coding: utf-8 -*-

import os

pipe_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

猜你喜欢

转载自blog.csdn.net/ternence_hsu/article/details/106276266