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
默认情况下,该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-build
Sublime 附带的命令使用此参数来确保python
输出是无缓冲的,并且使用该构建系统可以按示例程序的预期工作。
我不使用 Anaconda 包,所以我不确定它是否提供自己的构建系统,但您可能需要检查您正在使用的构建命令以确保它使用-u
.
归档时间: |
|
查看次数: |
815 次 |
最近记录: |