谁都不许动我的砖 2020-06-18 21:12 采纳率: 0%
浏览 1109

python如何获取exe软件输出的log日志

exe文件也是用python写的,拿pyinstaller转成了exe。这个exe会在结束的时候输出warning级别的日志。比如logger.warning("hello world")输出“hello world”。那么我如何在主线程调用这个exe子程序的时候,获取到这个“hello world”呢?

  • 写回答

1条回答 默认 最新

  • Valtava 2020-06-18 22:48
    关注

    取决于你用什么库调用,也取决于除了 warning 有没有其他信息

    举个例子,假设你使用suprocess,Python >= 3.3.4,程序的唯一输出就是你要的信息

    import subprocess
    
    message_string = subprocess.getoutput('your_exe.exe')
    

    或者使用 Popen,可以设置 stderr 为 PIPE,之后就可以当成普通流/文件对象使用了

    # warning 信息为 strerr,而不是 stdout
    proc = suprocess.Popen(['your_exe.exe'], stderr=subprocess.PIPE)
    
    message_bytes = proc.stderr.read()
    

    或者可以使用 Popen.communicate()

    proc = suprocess.Popen(['your_exe.exe'], stderr=subprocess.PIPE)
    
    #proc.communicate() 返回 tuple: (stdout_bytes, stderr_bytes)
    message_bytes = proc.communicate()[1]
    
    评论

报告相同问题?

悬赏问题

  • ¥15 如何实现H5在QQ平台上的二次分享卡片效果?
  • ¥15 python爬取bilibili校园招聘网站
  • ¥30 求解达问题(有红包)
  • ¥15 请解包一个pak文件
  • ¥15 不同系统编译兼容问题
  • ¥100 三相直流充电模块对数字电源芯片在物理上它必须具备哪些功能和性能?
  • ¥30 数字电源对DSP芯片的具体要求
  • ¥20 antv g6 折线边如何变为钝角
  • ¥30 如何在Matlab或Python中 设置饼图的高度
  • ¥15 nginx中的CORS策略应该如何配置