<bdo id='3lgM4'></bdo><ul id='3lgM4'></ul>
    <tfoot id='3lgM4'></tfoot>
  • <i id='3lgM4'><tr id='3lgM4'><dt id='3lgM4'><q id='3lgM4'><span id='3lgM4'><b id='3lgM4'><form id='3lgM4'><ins id='3lgM4'></ins><ul id='3lgM4'></ul><sub id='3lgM4'></sub></form><legend id='3lgM4'></legend><bdo id='3lgM4'><pre id='3lgM4'><center id='3lgM4'></center></pre></bdo></b><th id='3lgM4'></th></span></q></dt></tr></i><div id='3lgM4'><tfoot id='3lgM4'></tfoot><dl id='3lgM4'><fieldset id='3lgM4'></fieldset></dl></div>

    <small id='3lgM4'></small><noframes id='3lgM4'>

    <legend id='3lgM4'><style id='3lgM4'><dir id='3lgM4'><q id='3lgM4'></q></dir></style></legend>

        子进程中'shell = True'的实际含义

        Actual meaning of #39;shell=True#39; in subprocess(子进程中shell = True的实际含义)

        <legend id='qnVoI'><style id='qnVoI'><dir id='qnVoI'><q id='qnVoI'></q></dir></style></legend>

        <small id='qnVoI'></small><noframes id='qnVoI'>

      1. <tfoot id='qnVoI'></tfoot>
          <tbody id='qnVoI'></tbody>

                <i id='qnVoI'><tr id='qnVoI'><dt id='qnVoI'><q id='qnVoI'><span id='qnVoI'><b id='qnVoI'><form id='qnVoI'><ins id='qnVoI'></ins><ul id='qnVoI'></ul><sub id='qnVoI'></sub></form><legend id='qnVoI'></legend><bdo id='qnVoI'><pre id='qnVoI'><center id='qnVoI'></center></pre></bdo></b><th id='qnVoI'></th></span></q></dt></tr></i><div id='qnVoI'><tfoot id='qnVoI'></tfoot><dl id='qnVoI'><fieldset id='qnVoI'></fieldset></dl></div>
                  <bdo id='qnVoI'></bdo><ul id='qnVoI'></ul>
                • 本文介绍了子进程中'shell = True'的实际含义的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我正在使用 subprocess 模块调用不同的进程.不过,我有一个问题.

                  I am calling different processes with the subprocess module. However, I have a question.

                  在以下代码中:

                  callProcess = subprocess.Popen(['ls', '-l'], shell=True)
                  

                  callProcess = subprocess.Popen(['ls', '-l']) # without shell
                  

                  两者都有效.阅读文档后,我知道 shell=True 意味着通过 shell 执行代码.这意味着在缺席的情况下,直接启动该过程.

                  Both work. After reading the docs, I came to know that shell=True means executing the code through the shell. So that means in absence, the process is directly started.

                  那么对于我的情况,我应该更喜欢什么 - 我需要运行一个进程并获取它的输出.从 shell 内部或外部调用它有什么好处.

                  So what should I prefer for my case - I need to run a process and get its output. What benefit do I have from calling it from within the shell or outside of it.

                  推荐答案

                  不通过 shell 调用的好处是您不会调用神秘程序".在 POSIX 上,环境变量 SHELL 控制调用哪个二进制文件作为shell".在 Windows 上,没有 bourne shell 后代,只有 cmd.exe.

                  The benefit of not calling via the shell is that you are not invoking a 'mystery program.' On POSIX, the environment variable SHELL controls which binary is invoked as the "shell." On Windows, there is no bourne shell descendent, only cmd.exe.

                  因此调用 shell 会调用用户选择的程序,并且是平台相关的.一般来说,避免通过 shell 调用.

                  So invoking the shell invokes a program of the user's choosing and is platform-dependent. Generally speaking, avoid invocations via the shell.

                  通过 shell 调用确实允许您根据 shell 的通常机制扩展环境变量和文件 glob.在 POSIX 系统上,shell 将文件 glob 扩展为文件列表.在 Windows 上,无论如何,shell 不会扩展文件 glob(例如,*.*")(但命令行上的环境变量由 cmd.exe 扩展).

                  Invoking via the shell does allow you to expand environment variables and file globs according to the shell's usual mechanism. On POSIX systems, the shell expands file globs to a list of files. On Windows, a file glob (e.g., "*.*") is not expanded by the shell, anyway (but environment variables on a command line are expanded by cmd.exe).

                  如果您认为您需要环境变量扩展和文件 glob,请研究 1992 年对通过 shell 执行子程序调用的网络服务的 ILS 攻击.示例包括涉及 ILS 的各种 sendmail 后门.

                  If you think you want environment variable expansions and file globs, research the ILS attacks of 1992-ish on network services which performed subprogram invocations via the shell. Examples include the various sendmail backdoors involving ILS.

                  总之,使用 shell=False.

                  这篇关于子进程中'shell = True'的实际含义的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Pythonic and efficient way of finding adjacent cells in grid(在网格中查找相邻单元格的 Pythonic 和有效方法)
                  map a hexagonal grid in matplotlib(在 matplotlib 中映射六边形网格)
                  Execute arbitrary python code remotely - can it be done?(远程执行任意 python 代码 - 可以吗?)
                  Python - Plotting colored grid based on values(Python - 根据值绘制彩色网格)
                  Is there a GUI design app for the Tkinter / grid geometry?(是否有 Tkinter/网格几何图形的 GUI 设计应用程序?)
                  tkinter Canvas Scrollbar with Grid?(带有网格的 tkinter 画布滚动条?)

                • <tfoot id='IteR0'></tfoot>
                • <i id='IteR0'><tr id='IteR0'><dt id='IteR0'><q id='IteR0'><span id='IteR0'><b id='IteR0'><form id='IteR0'><ins id='IteR0'></ins><ul id='IteR0'></ul><sub id='IteR0'></sub></form><legend id='IteR0'></legend><bdo id='IteR0'><pre id='IteR0'><center id='IteR0'></center></pre></bdo></b><th id='IteR0'></th></span></q></dt></tr></i><div id='IteR0'><tfoot id='IteR0'></tfoot><dl id='IteR0'><fieldset id='IteR0'></fieldset></dl></div>

                        <bdo id='IteR0'></bdo><ul id='IteR0'></ul>
                      • <small id='IteR0'></small><noframes id='IteR0'>

                            <tbody id='IteR0'></tbody>
                          <legend id='IteR0'><style id='IteR0'><dir id='IteR0'><q id='IteR0'></q></dir></style></legend>