python标准输出,捕获python程序的标准输出

I'm trying to write a C# program that captures the standard output in a python program. My problem is that all of the output comes after the program has executed rather than when it actually happens. As an example, for this python program:

print "Hello"

time.sleep(2)

print "Hello"

I would expect to get "Hello", a two second gap, and then another "Hello". The actual result is a two second gap and then "Hello", "Hello".

If I run the above python script from the command line, I get the desired behaviour. If the command prompt can do this, then I should be able to mimic that functionality without having to flush the buffer repeatedly.

I'm using this to run the process from C#:

_proc = new Process

{

StartInfo = new ProcessStartInfo

{

FileName = "C:\\Python27\\python.exe",

Arguments = pyScript,

RedirectStandardError = true,

UseShellExecute = false,

RedirectStandardOutput = true,

CreateNoWindow = true

}

};

_proc.OutputDataReceived += ProcOnOutputDataReceived;

_proc.Start();

_proc.BeginOutputReadLine();

I can run this C# code (and changing the ProcessStartInfo properties above to run C# executable) and it behaves correctly:

Console.WriteLine("Hello");

Thread.Sleep(2000);

Console.WriteLine("Hello");

With this code I get "Hello", a two second gap, and then another "Hello".

Any idea why? How can I get the python interpreter to send the standard output as it happens?

解决方案

I know this is old but running python with -u (unbuffered) seems to be what you were after

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值