AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / computer / 问题 / 1421123
Accepted
interstar
interstar
Asked: 2019-04-04 15:31:13 +0800 CST2019-04-04 15:31:13 +0800 CST 2019-04-04 15:31:13 +0800 CST

看着一些东西被写入一个带有尾巴的文件

  • 772

我有一个 python 程序,它正在慢慢地生成一些输出。

我想将其捕获到一个文件中,但我也认为我可以用 tail 实时观看它。

所以在一个终端我正在做:

python myprog.py > output.txt

在另一个终端:

tail -f output.txt

但在 python 程序运行时,尾巴似乎没有向我显示任何内容。

如果我按 ctrl-c 来终止 python 脚本,突然尾部output.txt开始填满。但不是在 python 运行时。

我究竟做错了什么?

linux command-line redirection
  • 5 5 个回答
  • 6031 Views

5 个回答

  • Voted
  1. Best Answer
    Davey
    2019-04-04T16:05:24+08:002019-04-04T16:05:24+08:00

    您可能还需要显式刷新缓冲区,以便在生成时通过管道传输。这是因为输出通常仅在管道的缓冲区填满(我相信以千字节为单位)以及标准输入消息结束时打印。这可能是为了节省读/写。您可以在每次打印后执行此操作,或者如果您正在循环,则在循环中最后一次打印后执行此操作。

    import sys
    ...
    print('Some message')
    sys.stdout.flush()
    
    • 44
  2. BHC
    2019-04-05T08:14:02+08:002019-04-05T08:14:02+08:00

    使用无缓冲标志运行 python:

    python -u myprog.py > output.txt
    

    然后将实时打印输出。

    • 34
  3. n8te
    2019-04-04T16:11:19+08:002019-04-04T16:11:19+08:00

    与其尝试跟踪实时文件,不如使用tee。它被用来做你想做的事情。

    来自男士 T 恤:

    tee(1) - Linux 手册页

    名称 tee - 从标准输入读取并写入标准输出和文件

    概要

    tee [OPTION]... [FILE]...
    

    描述

    将标准输入复制到每个文件,也复制到标准输出。

    -a, --append  
       append to the given FILEs, do not overwrite  
    -i, --ignore-interrupts  
       ignore interrupt signals   
    --help  
       display this help and exit  
    --version
       output version information and exit
    

    如果 FILE 是 -,再次复制到标准输出。

    所以在你的情况下你会运行:

    python myprog.py | tee output.txt
    

    编辑:正如其他人指出的那样,这个答案将遇到 OP 最初遇到的相同问题,除非sys.stdout.flush()如 Davey 接受的答案中所述在 python 程序中使用。我在发布此答案之前所做的测试并未准确反映 OP 的用例。

    tee仍然可以用作显示输出同时写入文件的替代方法——尽管不是最佳方法,但 Davey 的答案显然是正确且最佳的答案。

    • 19
  4. Peter Cordes
    2019-04-05T11:18:07+08:002019-04-05T11:18:07+08:00

    术语:在这种情况下,任何地方都没有管道。(我编辑了问题来解决这个问题)。管道是一种不同类型的文件(内核中的缓冲区)。

    这是到常规文件的重定向。

    C stdio 和 Python 在连接到 TTY 时默认使 stdout 行缓冲,否则它是全缓冲的。行缓冲意味着缓冲区在换行后被刷新。全缓冲意味着它只有在满时才被刷新以对操作系统可见(即通过write()系统调用)。

    您最终会看到输出,一次可能是 4kiB 的块。(我不知道默认的缓冲区大小。)这通常更有效,意味着对实际磁盘的写入更少。但对于交互式监控来说不是很好,因为输出隐藏在写入进程的内存中,直到它被刷新。

    在 Stack Overflow 上,有一个Disable output buffering Python Q&A,其中列出了许多在 Python 中将无缓冲(或行缓冲?)输出输出到 stdout 的方法。问题本身总结了答案。

    选项包括运行python -u(或者我想放在#!/usr/bin/python -u脚本的顶部),或使用该PYTHONUNBUFFERED程序的环境变量。或在某些/所有print功能之后显式刷新,如@Davey 的回答所建议的那样。


    其他一些程序也有类似的选项,例如 GNU grep 有--line-buffered,而 GNUsed有-u/ --unbuffered,用于这样的用例,或者例如管道 python 程序的输出。例如./slowly-output-stuff | grep --line-buffered 'foo.*bar'。

    • 9
  5. d-n
    2019-04-09T12:29:26+08:002019-04-09T12:29:26+08:00

    当我使用 tail 时,它几乎总是跟踪日志文件,例如(电子邮件)消息。

    这可能有点离谱,但为什么不在 Python 代码中使用 // 而不是使用日志记录模块print?(来自 PSL)注意,日志格式器可以配置为不输出与传统日志相关的所有时间和 ID 代码。print()write()

    输出可以配置为转到(数据)文件,并且由于没有缓冲延迟或重定向,tail 可以愉快且即时地工作。

    问候

    • 0

相关问题

  • Python 的“pass”参数的批处理等价物是什么?

  • 禁用后无法启用 Microsoft Print to PDF

  • 以 root 身份运行 docker 容器

  • 如何在域和 Linux 活动目录中启用指纹传感器

  • 如何在CentOS 7 中将Ctrl+C 永久更改为Ctrl+K?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    Windows 10 服务称为 AarSvc_70f961。它是什么,我该如何禁用它?

    • 2 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Marko Smith

    ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] 证书验证失败:无法获取本地颁发者证书 (_ssl.c:1056)

    • 4 个回答
  • Marko Smith

    我如何知道 Windows 安装在哪个驱动器上?

    • 6 个回答
  • Martin Hope
    Albin 支持结束后如何激活 WindowsXP? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 “HTTPS Everywhere”仍然相关吗? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch Windows 10 删除大量小文件的速度非常慢。有什么办法可以加快速度吗? 2019-09-23 06:05:43 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    Inter Sys Ctrl+C 和 Ctrl+V 是如何工作的? 2019-05-15 02:51:21 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve