在 Sublime Text 3 中运行 Python 时如何删除输出缓冲

Opp*_*ppy 5 python sublimetext3

构建 Python 3 脚本时,如何从 Sublime Text 3 中删除输出缓冲?我想要实时输出。

我正在使用带有 Anaconda 插件、Python 3.6 和 Linux Mint 18 的 Sublime Text 3。当我使用 control-b 运行一个简单的脚本时:

print('hello')
Run Code Online (Sandbox Code Playgroud)

我在一个名为“构建输出”的单独窗口中得到一个即时输出。当我使用具有重复输出的脚本时,例如:

from time import sleep

count = 0
print('starting')
while True:
    print('{} hello'.format(count))
    count += 1
    sleep(0.5)
Run Code Online (Sandbox Code Playgroud)

最初我在“构建输出”中得到一个空白屏幕。一段时间后,它填充了数百行输出。看起来输出正在被缓冲。当缓冲区已满时,它会立即将所有内容输出到“构建输出”屏幕。

编辑 Sublime Text 允许自定义构建配置。默认的 Python 构建是针对 Python 2 的。我输入了 Python 3 的构建配置,但错过了 -u 标志。解决方法是将 -u 标志放在 Python 3 构建中。

文件:Python3.sublime-build

{
    "shell_cmd": "/usr/bin/env python3 -u ${file}",
    "selector": "source.python",
    "file_regex": "^(...*?):([0-9]*):?([0-9]*)",
    "working_dir": "${file_path}",
}
Run Code Online (Sandbox Code Playgroud)

保存在 sublime_install/Data/Packages/User/Python3.sublime-build

Oda*_*urd 3

默认情况下,该exec命令用于执行构建系统中的命令,并且该exec命令根本不缓冲输出。这个答案中有更多信息(它还提供了一个进行行缓冲的版本exec),但简而言之,exec启动一个线程来处理stdout和一个线程来处理stderr,并且两者在获得数据后立即将其转发到面板。

因此,像您在此处描述的问题通常是由程序进行自己的缓冲引起的。根据您使用的语言和平台,缓冲可能会以意想不到的方式改变您的预期:

例如,请参阅Linux 下的手册页中的以下文本:stdout

流 stderr 是无缓冲的。当流 stdout 指向终端时,它是行缓冲的。在调用 fflush(3) 或 exit(3) 或打印换行符之前,部分行不会出现。这可能会产生意外的结果,特别是在调试输出时。

在一般情况下,此问题的解决方案是修改程序本身以确保它不会缓冲,具体操作方法取决于您使用的语言和所在的平台。它可以像设置环境变量一样简单,也可以像启动代码一样复杂,以确保无论情况如何,缓冲都会按照您的预期进行设置。

在 Python 的特定情况下,-u解释器的命令行参数告诉 Python 保持无缓冲:

-u     : unbuffered binary stdout and stderr; also PYTHONUNBUFFERED=x
         see man page for details on internal buffering relating to '-u'
Run Code Online (Sandbox Code Playgroud)

Python.sublime-buildSublime 附带的命令使用此参数来确保python输出是无缓冲的,并且使用该构建系统可以按示例程序的预期工作。

我不使用 Anaconda 包,所以我不确定它是否提供自己的构建系统,但您可能需要检查您正在使用的构建命令以确保它使用-u.