草庐IT

STDOUT_FILENO

全部标签

python - 为什么 `subprocess.check_call(..., stderr=sys.stdout)` 在 Python 2.6 中失败?

Python2.6.9(unknown,Mar72016,11:15:18)[GCC5.3.0]onlinux2Type"help","copyright","credits"or"license"formoreinformation.>>>importsys>>>importsubprocess>>>subprocess.check_call(['echo','hi'],stderr=sys.stdout)echo:writeerror:BadfiledescriptorTraceback(mostrecentcalllast):File"",line1,inFile"/usr/li

python - Argparse 和 ArgumentDefaultsHelpFormatter。选择 sys.stdin/stdout 作为默认值时的默认值格式

我对使用argparse的ArgumentDefaultsHelpFormatter类格式化程序很感兴趣(我的程序有几个子命令)。默认情况下,输入和输出参数分别设置为sys.stdin和sys.stdout。但是,这两个参数的格式可能会让用户有点困惑(例如(默认值:',mode'r'at0x10028e0c0>)。有没有一种方法可以专门轻松地更改这两个参数的输出格式以获得像“默认:STDIN”或“默认:STDOUT”之类的东西?谢谢importsysimportargparseparser=argparse.ArgumentParser(prog='PROG',formatter_cl

python - 为什么在控制台中写入 stdout 会附加写入的字符数,在 Python 3 中?

我刚刚在Python控制台中使用sys.stdout.write()时,我注意到这会产生一些奇怪的输出。对于每个write()调用,分别传递给函数的写入字符数将追加到控制台的输出中。>>>sys.stdout.write('foobar')例如导致foobar7被打印出来。即使传递空字符串也会导致输出0。这实际上只发生在Python控制台中,但在执行具有相同语句的文件时不会发生。更有趣的是,它只发生在Python3上,而不会发生在Python2上。虽然这对我来说不是真正的问题,因为它只发生在控制台中,但我真的很想知道为什么它会这样。我的Python版本是Ubuntu15.10下的3.5

python - 从在 *nix 环境中调用的 python 脚本重定向 stdout 无法正常工作

我有一个Python程序,其中有一些Print语句,然后调用了一些c++可执行文件,我还从中获得了一些输出到标准输出。当我在unix终端中运行这个python脚本时,我在屏幕上得到了预期的输出(以正确的顺序,即首先从打印然后从c++可执行文件)。问题是当我将此输出重定向到类似的文件时pythontest.py>out.txt我得到的输出顺序错误。我先得到c++可执行文件的输出,然后得到另一个。 最佳答案 您可以使用命令行开关-u以无缓冲输出运行python,即您可以只调用python-umyscript.py并且到stdout的输出

python - 删除 ANSI 颜色代码时打印到 STDOUT 和日志文件

我有以下功能可以为我的屏幕消息着色:deferror(string):return'\033[31;1m'+string+'\033[0m'defstandout(string):return'\033[34;1m'+string+'\033[0m'我按如下方式使用它们:printerror('Therewasaproblemwiththeprogram')print"Thisisnormal"+standout("andthisstandsout")我想将输出记录到一个没有ANSI颜色代码的文件(除了STDOUT之外),希望不必在每个print语句中添加第二个“记录”行。原因是,如果

python - 如果我在 subprocess.Popen() 中不使用 stdout=subprocess.PIPE 有什么区别?

我最近在Python中注意到subprocess.Popen()有一个参数:stdout=None(default)我还看到有人使用stdout=subprocess.PIPE。有什么区别?我应该使用哪一个?另一个问题是,为什么wait()函数有时不能等到进程真正完成?我用过:a=sp.Popen(....,shell=True)a.wait()a2=sp.Popen(...,shell=True)a2.wait()有时a2命令在命令a完成之前执行。 最佳答案 stdout=None表示,进程的stdout-handle直接从父进程

python - 使用 subprocess.Popen() 时,stderr 和 stdout 没有输出

我正在使用Python自动执行SVN提交,我想将SVN命令的输出写入日志文件。我拥有的代码可以使SVN运行,但问题是在成功提交时,subprocess调用不会为我的日志返回任何输出。相比之下,当我手动运行SVN时,我得到的输出显示了命令的进度并显示了正在提交的文件。这就是我想要在我的日志文件中的内容。SVN是否将该数据输出到缓冲区而不是stdout或stderr?如何为我的日志捕获该数据?这是我使用的代码:cmd="svncommit--non-interactive--no-auth-cache-m'Automaticcommit'./"process=subprocess.Pope

python - 在 Python 中使用 sys.stdout.write 嵌入变量

我可以通过这种方式在python中使用print语句嵌入变量i=10print"Valueis%s"%(i)输出Valueis10但是这样做i=10sys.stdout.write("Valueis%s")%(i)给我以下错误TypeError:unsupportedoperandtype(s)for%:'NoneType'and'int'我可以使用sys.stdout.write而不是print来嵌入变量吗? 最佳答案 你把括号弄错了。应该是i=10sys.stdout.write("Valueis%s"%i)%运算符将字符串和元

python unicode处理打印和sys.stdout.write之间的差异

首先我会说我已经看过这篇文章:Strangepythonprintbehaviorwithunicode,但那里提供的解决方案(使用PYTHONIOENCODING)对我不起作用。这是我的问题:Python2.6.5(r265:79063,Apr92010,11:16:46)[GCC4.1.220080704(RedHat4.1.2-44)]onlinux2>>>a=u'\xa6'>>>printa¦工作得很好,但是:>>>sys.stdout.write(a)Traceback(mostrecentcalllast):File"",line1,in?UnicodeEncodeErr

Python Popen().stdout.read() 挂起

我正在尝试使用Python的subprocess.Popen获取另一个脚本的输出,如下所示process=Popen(command,stdout=PIPE,shell=True)exitcode=process.wait()output=process.stdout.read()#hangshere它卡在第三行,只有当我将它作为python脚本运行并且我无法在pythonshell中重现时才挂起。另一个脚本只打印了几个字,我假设这不是缓冲区问题。有人知道我在这里做错了什么吗? 最佳答案 您可能想使用.communicate()而不