V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
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 · 2016-05-12 15:12:01 +08:00 · 3425 次点击
    这是一个创建于 3122 天前的主题,其中的信息可能已经有所发展或是发生改变。
    创建了个守护进程,然后将标准输出重定向到一个文件,
    但是发现这个文件里面并没有什么东西,如果不重定向可以正常输出到终端,
    我用 python 终端打开这个文件: open("file","a+",0)也是能写入内容的,
    所以想让大家帮忙看看哪个地方有问题
    代码地址: https://github.com/EchoUtopia/my-python-practices/blob/master/watch_sync.py
    在相关代码 make_deamon 函数里
    5 条回复    2016-05-16 21:51:13 +08:00
    mengzhuo
        1
    mengzhuo  
       2016-05-12 23:46:57 +08:00 via iPhone
    进程之间没有联系啊
    你以为子进程会把输出都自动发到父进程里么……
    EchoUtopia
        2
    EchoUtopia  
    OP
       2016-05-13 18:06:55 +08:00
    @mengzhuo 子进程会继承父进程的文件描述符啊,所以标准输入输出都继承下来了,我试验的时候把 os.dup2()重定向那部分去掉, print 信息都会输出到终端
    WKPlus
        3
    WKPlus  
       2016-05-13 21:13:52 +08:00
    怀疑是 buffer 的原因。
    stdout 是屏幕输出的时候,是 line buffer 的;重定向到文件的话,是 fully buffer 的。
    stderr 重定向到文件的话,也不是 fully buffer 的,你可以试试 stderr 的输出能不能看到,或者 stdout 多写点内容估计就能看到了
    EchoUtopia
        4
    EchoUtopia  
    OP
       2016-05-16 10:35:13 +08:00
    @WKPlus 我开始也感觉是 buffer ,但是 python 的 open 第三个参数设为 0 就去掉 buffer 了,但是还是不行
    WKPlus
        5
    WKPlus  
       2016-05-16 21:51:13 +08:00
    @EchoUtopia 我觉得你可以做两个测试: 1. 试试看 stderr 的输出能不能打印到文件 2. stdout 多打印点内容看看
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3488 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 00:46 · PVG 08:46 · LAX 16:46 · JFK 19:46
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.