Python不打印输出

mar*_*ark 5 python

我正在学习在 python 中使用电子 js,我正在使用python-shell,所以我有以下简单的 python 脚本:

import sys, json

# simple JSON echo script
for line in sys.stdin:
    print(json.dumps(json.loads(line)))
Run Code Online (Sandbox Code Playgroud)

在我的 main.js 中:

let {PythonShell} = require('python-shell')
let pyshell = new PythonShell('/home/bassel/electron_app/pyapp/name.py', {mode : 'json'});
pyshell.send({name:"mark"})


pyshell.on('message', function (message) {
    // received a message sent from the Python script (a simple "print" statement)
    console.log("hi");
});
Run Code Online (Sandbox Code Playgroud)

但是hi没有打印出来,有什么问题?

snw*_*flk 6

输出通常被缓冲以保留系统资源。这意味着在这种情况下,系统会阻止 Python 输出,直到有足够的内容一起发布。

为了克服这个问题,您可以明确地“刷新”输出:

import sys, json

# simple JSON echo script
for line in sys.stdin:
    print(json.dumps(json.loads(line)))
    sys.stdout.flush()                      # <--- added line to flush output
Run Code Online (Sandbox Code Playgroud)

如果您使用的是 Python 3.3 或更高版本,您也可以使用:

import sys, json

# simple JSON echo script
for line in sys.stdin:
    print(json.dumps(json.loads(line)), flush=True)   # <--- added keyword
Run Code Online (Sandbox Code Playgroud)