V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
EchoUtopia
V2EX  ›  Python

python 文件重定向无效,求帮忙看看

  •  
  •   EchoUtopia · May 12, 2016 · 3933 views
    This topic created in 3647 days ago, the information mentioned may be changed or developed.
    创建了个守护进程,然后将标准输出重定向到一个文件,
    但是发现这个文件里面并没有什么东西,如果不重定向可以正常输出到终端,
    我用 python 终端打开这个文件: open("file","a+",0)也是能写入内容的,
    所以想让大家帮忙看看哪个地方有问题
    代码地址: https://github.com/EchoUtopia/my-python-practices/blob/master/watch_sync.py
    在相关代码 make_deamon 函数里
    5 replies    2016-05-16 21:51:13 +08:00
    mengzhuo
        1
    mengzhuo  
       May 12, 2016 via iPhone
    进程之间没有联系啊
    你以为子进程会把输出都自动发到父进程里么……
    EchoUtopia
        2
    EchoUtopia  
    OP
       May 13, 2016
    @mengzhuo 子进程会继承父进程的文件描述符啊,所以标准输入输出都继承下来了,我试验的时候把 os.dup2()重定向那部分去掉, print 信息都会输出到终端
    WKPlus
        3
    WKPlus  
       May 13, 2016
    怀疑是 buffer 的原因。
    stdout 是屏幕输出的时候,是 line buffer 的;重定向到文件的话,是 fully buffer 的。
    stderr 重定向到文件的话,也不是 fully buffer 的,你可以试试 stderr 的输出能不能看到,或者 stdout 多写点内容估计就能看到了
    EchoUtopia
        4
    EchoUtopia  
    OP
       May 16, 2016
    @WKPlus 我开始也感觉是 buffer ,但是 python 的 open 第三个参数设为 0 就去掉 buffer 了,但是还是不行
    WKPlus
        5
    WKPlus  
       May 16, 2016
    @EchoUtopia 我觉得你可以做两个测试: 1. 试试看 stderr 的输出能不能打印到文件 2. stdout 多打印点内容看看
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1315 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 42ms · UTC 23:49 · PVG 07:49 · LAX 16:49 · JFK 19:49
    ♥ Do have faith in what you're doing.