博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python处理ctype模块的输出日志
阅读量:4200 次
发布时间:2019-05-26

本文共 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/

你可能感兴趣的文章
Project 2013项目管理教程(1):项目管理概述及预备
查看>>
ssh客户端后台运行
查看>>
哥去求职,才说了一句话考官就让我出去
查看>>
【React Native】把现代web科技带给移动开发者(一)
查看>>
【GoLang】Web工作方式
查看>>
Launch Sublime Text 3 from the command line
查看>>
【数据库之mysql】mysql的安装(一)
查看>>
【数据库之mysql】 mysql 入门教程(二)
查看>>
【HTML5/CSS/JS】A list of Font Awesome icons and their CSS content values(一)
查看>>
【HTML5/CSS/JS】<br>与<p>标签区别(二)
查看>>
【HTML5/CSS/JS】开发跨平台应用工具的选择(三)
查看>>
【心灵鸡汤】Give it five minutes不要让一个好主意随风而去
查看>>
【React Native】Invariant Violation: Application AwesomeProject has not been registered
查看>>
【ReactNative】真机上无法调试 could not connect to development server
查看>>
【XCode 4.6】常用快捷键 特别是格式化代码ctrl+i
查看>>
【iOS游戏开发】icon那点事 之 实际应用(二)
查看>>
【iOS游戏开发】icon那点事 之 图标设计(三)
查看>>
【IOS游戏开发】之测试发布(Distribution)
查看>>
【IOS游戏开发】之IPA破解原理
查看>>
【一天一道LeetCode】#45. Jump Game II
查看>>