- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试读取从 Python 调用的子进程的输出。为此,我使用 Popen(因为我认为如果使用 subprocess.call 则无法通过管道传输标准输出)。
截至目前,我有两种方法可以做到这一点,在测试中,它们似乎提供了相同的结果。代码如下:
with Popen(['Robocopy', source, destination, '/E', '/TEE', '/R:3', '/W:5', '/log+:log.txt'], stdout=PIPE) as Robocopy:
for line in Robocopy.stdout:
line = line.decode('ascii')
message_list = [item.strip(' \t\n').replace('\r', '') for item in line.split('\t') if item != '']
print(message_list[0], message_list[0])
Robocopy.wait()
returncode = Robocopy.returncode
和
with Popen(['Robocopy', source, destination, '/E', '/TEE', '/R:3', '/W:5', '/log+:log.txt'], stdout=PIPE, universal_newlines=True, bufsize=1) as Robocopy:
for line in Robocopy.stdout:
message_list = [item.strip() for item in line.split('\t') if item != '']
print(message_list[0], message_list[2])
Robocopy.wait()
returncode = Robocopy.returncode
第一种方法不包括 universal_newlines=True,因为文档说明这是 only usable if universal_newlines=True i.e., in a text mode .
第二个版本确实包含 universal_newlines,因此我指定了一个 bufsize。
有人能给我解释一下区别吗?我找不到这篇文章,但我确实读到了有关导致某种问题的缓冲区溢出问题以及使用 for line in stdout
的重要性。 .
此外,在查看输出时,不指定 universal_newlines 会使标准输出成为 bytes
对象 - 但我不确定如果我只用 ascii
解码字节对象会有什么不同? (就换行符和制表符而言)比较了 universal_newlines 模式。
最后,设置 bufsize
至 1
使输出“行缓冲”,但我不确定这意味着什么。如果能解释一下这些不同的元素是如何结合在一起的,我将不胜感激。谢谢
最佳答案
What is the difference between using universal_newlines=True (with bufsize=1) and using default arguments with Popen
默认值为:universal_newlines=False
(表示输入/输出被接受为字节,而不是Unicode 字符串加上 universal newlines mode 处理(因此是参数的名称。Python 3.7 提供了 text
别名,这里可能更直观)被禁用——您按原样获得二进制数据(除非 POSIX 层在Windows 把它搞砸了)和 bufsize=-1
(意味着流被完全缓冲——使用默认缓冲区大小)。
universal_newlines=True
使用 locale.getpreferredencoding(False)
字符编码来解码字节(这可能与您使用的 ascii
编码不同代码)。
如果 universal_newlines=False
则 for line in Robocopy.stdout:
遍历 b'\n'
分隔的行。如果进程使用非 ascii 编码,例如 UTF-16 作为其输出,那么即使 os.linesep == '\n'
在您的系统上;你可能会得到错误的结果。如果您想使用文本行,请使用文本模式:明确传递 universal_newlines=True
或使用 io.TextIOWrapper(process.stdout)
。
The second version does include universal_newlines and therefore I specify a bufsize.
通常,如果您使用universal_newlines
,则不必指定bufsize
(您可以但不是必需的)。而且您不需要在您的情况下指定 bufsize
。 bufsize=1
启用行缓冲模式(如果您要写入 process.stdin
,输入缓冲区会在换行时自动刷新)否则它等同于默认的 bufsize=-1
.
关于python - 使用 universal_newlines=True(bufsize=1)和使用 Popen 的默认参数有什么区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38181494/
有谁知道 bufsize 的公式是什么以及它在 FFMPEG 中检查的速率? 我似乎找不到任何具体的答案。 是吗: bufsize = 比特率/速率 ? 它应该在计算中使用 maxrate 而不是 b
我试图运行并处理某个 java 程序的标准输出,发现我的 Python 脚本永远在等待。然后我编写了一个新的测试脚本来测试 subprocess 并再次发现运行此脚本时没有看到任何输出: $ cat
我正在制作一个小程序,我可以使用它的默认编辑器从计算机的任何部分打开文件。这是我的代码: from os import * import subprocess print("Welcome to my
对于一项作业,我应该创建两种方法:方法一是 read()和 write()输入文件到一个空的输出文件,一次一个字节(慢慢地)。 另一种方法将改为使用 char buf[BUFSIZ];其中 BUFSI
$ getconf BUFSIZgetconf: Unrecognized variable 'BUFSIZ' 是否有一种标准方法可以从 shell 中确定 BUFSIZ 的值?编写一个简单的 C 程
我有两个小的 python 文件,第一个使用 input 读取一行然后打印另一行 a = input() print('complete') 第二次尝试将其作为子进程运行 import subproc
背景信息 我正在尝试获取用户用户名的字符串,唯一提供的有关该用户的信息是他们的 uid 号码。由于先前调用 fstat,我有 uid(并且 uid 存储在 struct stat). 我需要以线程安全
我正在编写一个小型套接字程序 (GNU libc)。我有一个循环要求用户输入(例如“MSG>”)。当用户按下回车键时,消息被发送(当前发送到本地主机上的服务器)。 无论如何,我想从标准输入读取到字符缓
我正在尝试分析一些调用 readlink 的代码(不是我自己编写的)积极的bufsize ,然后测试结果是否为零。我看不出结果如何为零,我尝试过的所有内容都是-1,实际链接的大小或软链接(soft l
这个问题在这里已经有了答案: bufsize must be an integer error while grepping a message (1 个回答) 关闭 6 年前。 我正在尝试从一个目
我在尝试 grep 查找由日志中的多行组成的消息时遇到以下错误...任何人都可以提供有关如何克服此错误的输入吗? 代码:- print gerrit_commitmsg gerritl
我在 C 编程中遇到了这个问题: 问题:下面的代码片段中用零填充缓冲区的缺陷是什么?如何解决这个问题? char*buf; buf=malloc(BUFSIZ); memset(buf,0,BUFSI
我正在编写一个简单的 Linux USB 字符驱动程序,允许从它创建的设备节点读取一个短字符串。 它工作正常,但我注意到使用 cat 从设备节点读取和使用 Files.readAllBytes 从 J
我们是否使用 lu 和 unsigned long 强制转换,如: printf("%lu\n", (unsigned long)BUFSIZ); /* 512 */ 希望最好的?还是有别的办法? 这
我正在尝试读取从 Python 调用的子进程的输出。为此,我使用 Popen(因为我认为如果使用 subprocess.call 则无法通过管道传输标准输出)。 截至目前,我有两种方法可以做到这一点,
要从 python 中的套接字读取数据,请调用 socket.recv,它具有以下签名: socket.recv(bufsize[, flags]) python docs for socket.re
我正在尝试编写 python 文件,即 python 中的 wxtrac tar 文件。 据我所知,subprocess 是完成此任务的合适工具。 我写了下面的代码: from subprocess
在python中,方法是: socket.recv(bufsize[, flags]) 在C中,方法是: int recv( _In_ SOCKET s, _Out_ char *buf, _In_
我是一名优秀的程序员,十分优秀!