Windows 没有将命令行参数传递给从 shell 执行的 Python 程序

Posted

技术标签:

【中文标题】Windows 没有将命令行参数传递给从 shell 执行的 Python 程序【英文标题】:Windows is not passing command line arguments to Python programs executed from the shell 【发布时间】:2011-02-08 02:49:20 【问题描述】:

如果我尝试将命令行参数作为 Windows 命令 shell 中的可执行命令直接执行,我将无法获取传递给 Python 程序的命令行参数。例如,如果我有这个程序(test.py):

import sys
print "Args: %r" % sys.argv[1:]

并执行:

>test foo
Args: []

相比:

>python test.py foo
Args: ['foo']

我的配置有:

PATH=...;C:\python25;...
PATHEXT=...;.PY;....

>assoc .py
.py=Python.File

>ftype | grep Python
Python.CompiledFile="C:\Python25\python.exe" "%1" %*
Python.File="C:\Python25\python.exe" "%1" %*
Python.NoConFile="C:\Python25\pythonw.exe" "%1" %*

【问题讨论】:

但是它对我有用。 C:\Documents and Settings\Quim>test foo Args: ['foo'] 我将 test.py 放在 cmd.exe 的初始位置(属性中的 %HOMEDRIVE%%HOMEPATH%)。其余的我的设置没有什么特别的:winxp,Activepython 2.6.5 哇,多么令人沮丧的错误 :( 我刚刚重新安装了 Python,但它仍然坏掉了!两年前 Python 问题跟踪器报告了该错误 bugs.python.org/issue7936 但没有修复 - 很少有开发人员使用 Windows . 在我安装 python 3.4 并尝试使用 python 2.7 时遇到了这个问题。看起来 python 3.4 安装程序搞砸了? 如果系统使用[HKCU|HKLM]\SOFTWARE\Classes\Applications\python.exe[HKCU|HKLM\SOFTWARE\Classes\py_auto_file,则说明配置错误,应删除有问题的键。然后使用资源管理器(“打开方式”或文件关联设置应用程序)选择使用标准[HKCU|HKLM]\SOFTWARE\Classes\Python.File ProgId 的正确“Python”条目。检查 regedit 中的 shell\open\command 子键。如果安装了 Python 3,则命令模板应使用 py 启动器。如果为所有用户安装了启动器,则模板应为"C:\Windows\py.exe" "%1" %* cmd 的内部 assocftype 命令仅显示和修改 HKLM\SOFTWARE\Classes,因此它们需要管理员权限才能写入注册表,如果 Python 是,它们不是正确的工具为当前用户安装。您必须使用 regedit 修改 HKCU\SOFTWARE\Classes 中的每个用户设置,这优先于 HKLM 设置。此外,与 ProgId 的关联应始终通过 Explorer 管理,而不是使用 assoc。 Explorer 将用户的选择存储在HKCU\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\FileExts 【参考方案1】:

必须在 Windows 10 中对其进行修改才能使其正常工作(最后是 %*)

计算机\HKEY_USERS\S-1-5-21-2364940108-955964078-1358188674-1001\Software\Classes\Applications\py.exe\shell\open\command

【讨论】:

【参考方案2】:

非常感谢大多数其他答案帮助我找到解决方案!

我的情况是用py.exe(不是直接python.exe)打开.py-files,这种情况在几个cmets中都有记录,但我决定将其作为单独的答案发布以强调差异。

所以我的.py-文件与C:\Windows\py.exe 相关联,在C:\Windows\py.ini 配置中我有几个shebang 定义

[commands]
<my_venv_py> = C:\Programs\my_venv_py\Scripts\python.exe
<my_venv_py_w> = C:\Programs\my_venv_py\Scripts\pythonw.exe

像这样在我的脚本中使用#!&lt;MY_VENV_PY&gt;

在 Microsoft Windows 7 [版本 6.1.7601] 上,我的 python 脚本没有收到这样的参数

script.py 1 2

但这很好用

py script.py 1 2

文件关联正常

> assoc .py
.py=Python.File

> ftype | grep Python
File STDIN:
Python.CompiledFile="C:\Windows\py.exe" "%1" %*
Python.File=C:\Windows\py.exe "%L" %*
Python.NoConFile="C:\Windows\pyw.exe" "%1" %*

我已经尝试了很多注册表更改,但最后的帮助是以下更改(保存到.reg-文件并运行)。我发现此注册表项搜索 "%1" 初始值为 "C:\Windows\py.exe" "%1" 的字符串,并在最后添加 %* 作为其他答案说明:

Windows Registry Editor Version 5.00

[HKEY_CLASSES_ROOT\Applications\py.exe\shell\open\command]
@="\"C:\\Windows\\py.exe\" \"%1\" %*"

有关信息,在我尝试设置这些键和值但没有帮助之前(至少在上面提到的之前):

Windows Registry Editor Version 5.00

[HKEY_CLASSES_ROOT\.py]
@="Python.File"
[HKEY_CURRENT_USER\Software\Classes\.py]
@="Python.File"
[HKEY_LOCAL_MACHINE\SOFTWARE\Classes\.py]
@="Python.File"
[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\FileExts\.py]
@="Python.File"

[HKEY_CLASSES_ROOT\py_auto_file]
@="Python File"
[HKEY_CLASSES_ROOT\py_auto_file\shell\open\command]
@="\"C:\\Windows\\py.exe\" \"%1\" %*"

[HKEY_CLASSES_ROOT\Python.File]
@="Python File"
[HKEY_CLASSES_ROOT\Python.File\Shell\Open\command]
@="\"C:\\Windows\\py.exe\" \"%1\" %*"

【讨论】:

【参考方案3】:

如果通过编辑以下注册表项在我的 Windows 10 系统上修复此问题:

Computer\HKEY_CLASSES_ROOT\py_auto_file\shell\open\command
Computer\HKEY_CLASSES_ROOT\Python.File\Shell\Open\Command
Computer\HKEY_CLASSES_ROOT\Applications\python.exe\shell\open\command

到这个值:

"C:\Python27\python.exe" "%1" %*

【讨论】:

这是 python windows 安装程序中的错误吗?【参考方案4】:

通过查看 Windows 注册表,我找到了所有类似的地方 Python36\pythonw.exe "%1" %* 出现。

当我在命令提示符下键入python app.py args 时,一切正常。

当我只使用应用名称 (app.py args) 时,Windows 会在 Python 中打开 app.py,但应用在尝试访问 argv[1] 时会失败,因为 len(argv) 为 1。

显然,Windows 知道足以将 py 文件传递​​给 Python,但我无法通过查看注册表项来弄清楚它是如何构造命令的。它似乎使用"%1" 而不是"%1" %*

【讨论】:

【参考方案5】:

以下是针对 Python 3.6、2.7 和 Anaconda3 修复的 .reg 文件:

python-3.6.0.reg

Windows Registry Editor Version 5.00

[HKEY_CLASSES_ROOT\.py]
@="Python.File"
"Content Type"="text/plain"

[HKEY_CLASSES_ROOT\.pyc]
@="Python.CompiledFile"
"Content Type"="text/plain"

[HKEY_CLASSES_ROOT\.pyw]
@="Python.NoConFile"
"Content Type"="text/plain"


[HKEY_CLASSES_ROOT\py_auto_file]

[HKEY_CLASSES_ROOT\py_auto_file\DefaultIcon]
@="C:\\Python36\\DLLs\\py.ico"

[HKEY_CLASSES_ROOT\py_auto_file\shell\open\command]
@="\"C:\\Python36\\python.exe\" \"%1\" %*"


[HKEY_CLASSES_ROOT\Python.File]
@="Python File"

[HKEY_CLASSES_ROOT\Python.File\DefaultIcon]
@="C:\\Python36\\DLLs\\py.ico"

[HKEY_CLASSES_ROOT\Python.File\shell\open\command]
@="\"C:\\Python36\\python.exe\" \"%1\" %*"


[HKEY_CLASSES_ROOT\Python.CompiledFile]
@="Compiled Python File"

[HKEY_CLASSES_ROOT\Python.CompiledFile\DefaultIcon]
@="C:\\Python36\\DLLs\\pyc.ico"

[HKEY_CLASSES_ROOT\Python.CompiledFile\shell\open\command]
@="\"C:\\Python36\\python.exe\" \"%1\" %*"


[HKEY_CLASSES_ROOT\Python.NoConFile]
@="Python File (no console)"

[HKEY_CLASSES_ROOT\Python.NoConFile\DefaultIcon]
@="C:\\Python36\\DLLs\\py.ico"

[HKEY_CLASSES_ROOT\Python.NoConFile\shell\open\command]
@="\"C:\\Python36\\python.exe\" \"%1\" %*"

python-2.7.0.reg

Windows Registry Editor Version 5.00

[HKEY_CLASSES_ROOT\.py]
@="Python.File"
"Content Type"="text/plain"

[HKEY_CLASSES_ROOT\.pyc]
@="Python.CompiledFile"
"Content Type"="text/plain"

[HKEY_CLASSES_ROOT\.pyw]
@="Python.NoConFile"
"Content Type"="text/plain"


[HKEY_CLASSES_ROOT\py_auto_file]

[HKEY_CLASSES_ROOT\py_auto_file\DefaultIcon]
@="C:\\Python27\\DLLs\\py.ico"

[HKEY_CLASSES_ROOT\py_auto_file\shell\open\command]
@="\"C:\\Python27\\python.exe\" \"%1\" %*"


[HKEY_CLASSES_ROOT\Python.File]
@="Python File"

[HKEY_CLASSES_ROOT\Python.File\DefaultIcon]
@="C:\\Python27\\DLLs\\py.ico"

[HKEY_CLASSES_ROOT\Python.File\shell\open\command]
@="\"C:\\Python27\\python.exe\" \"%1\" %*"


[HKEY_CLASSES_ROOT\Python.CompiledFile]
@="Compiled Python File"

[HKEY_CLASSES_ROOT\Python.CompiledFile\DefaultIcon]
@="C:\\Python27\\DLLs\\pyc.ico"

[HKEY_CLASSES_ROOT\Python.CompiledFile\shell\open\command]
@="\"C:\\Python27\\python.exe\" \"%1\" %*"


[HKEY_CLASSES_ROOT\Python.NoConFile]
@="Python File (no console)"

[HKEY_CLASSES_ROOT\Python.NoConFile\DefaultIcon]
@="C:\\Python27\\DLLs\\py.ico"

[HKEY_CLASSES_ROOT\Python.NoConFile\shell\open\command]
@="\"C:\\Python27\\python.exe\" \"%1\" %*"

anaconda3.reg(更改用户名)

Windows Registry Editor Version 5.00

[HKEY_CLASSES_ROOT\.py]
@="Python.File"
"Content Type"="text/plain"

[HKEY_CLASSES_ROOT\.pyc]
@="Python.CompiledFile"
"Content Type"="text/plain"

[HKEY_CLASSES_ROOT\.pyw]
@="Python.NoConFile"
"Content Type"="text/plain"


[HKEY_CLASSES_ROOT\py_auto_file]

[HKEY_CLASSES_ROOT\py_auto_file\DefaultIcon]
@="C:\\Users\\username\\Anaconda3\\DLLs\\py.ico"

[HKEY_CLASSES_ROOT\py_auto_file\shell\open\command]
@="\"C:\\Users\\username\\Anaconda3\\python.exe\" \"%1\" %*"


[HKEY_CLASSES_ROOT\Python.File]
@="Python File"

[HKEY_CLASSES_ROOT\Python.File\DefaultIcon]
@="C:\\Users\\username\\Anaconda3\\DLLs\\py.ico"

[HKEY_CLASSES_ROOT\Python.File\shell\open\command]
@="\"C:\\Users\\username\\Anaconda3\\python.exe\" \"%1\" %*"


[HKEY_CLASSES_ROOT\Python.CompiledFile]
@="Compiled Python File"

[HKEY_CLASSES_ROOT\Python.CompiledFile\DefaultIcon]
@="C:\\Users\\username\\Anaconda3\\DLLs\\pyc.ico"

[HKEY_CLASSES_ROOT\Python.CompiledFile\shell\open\command]
@="\"C:\\Users\\username\\Anaconda3\\python.exe\" \"%1\" %*"


[HKEY_CLASSES_ROOT\Python.NoConFile]
@="Python File (no console)"

[HKEY_CLASSES_ROOT\Python.NoConFile\DefaultIcon]
@="C:\\Users\\username\\Anaconda3\\DLLs\\py.ico"

[HKEY_CLASSES_ROOT\Python.NoConFile\shell\open\command]
@="\"C:\\Users\\username\\Anaconda3\\python.exe\" \"%1\" %*"

【讨论】:

【参考方案6】:

我使用python.exepy_auto_file 检查了所有注册表项,并让它们指向我当前的python 安装,包括最后传递参数的%*。他们不少:

HKEY_CLASSES_ROOT\Applications\python.exe\shell\open\command:

org: "C:\miniconda3\python.exe" "%1" "%*" 已更改:“C:\Python35\python.exe”“%1”“%*”

HKEY_CLASSES_ROOT\py_auto_file\shell\open\command

org: "C:\Program Files\Sublime Text 3\sublime_text.exe" "%1" 已更改:“C:\Python35\python.exe”“%1”“%*”

HKEY_CURRENT_USER\Software\Classes\py_auto_file\shell\open\command

org: "C:\Python35\python.exe" "%1" "%*"

HKEY_USERS\S-1-5-21-2621213409-1291422344-4183577876-2165\Software\Classes\py_auto_file\shell\open\command

org: "C:\Python35\python.exe" "%1" "%*"

HKEY_USERS\S-1-5-21-2621213409-1291422344-4183577876-2165_Classes\py_auto_file\shell\open\command

org: "C:\Python35\python.exe" "%1" "%*"

HKEY_CLASSES_ROOT\Applications\pythonw.exe\shell\open\command

org: "C:\Python34\pythonw.exe" "%1" 已更改:“C:\Python35\pythonw.exe”“%1”“%*”

HKEY_CURRENT_USER\Software\Classes\Applications\python.exe\shell\open\command

org: "C:\Python35\python.exe" "%1" "%*"

但这并没有为我做这项工作。我还必须更改我的默认 python 应用程序。

可以看到,我安装了 3 个 Python 版本。不可能在这里看到哪个是哪个,所以我尝试了所有三个作为我的默认 python 应用程序。最终,我能够使用这三个之一来获取我的脚本参数。

【讨论】:

【参考方案7】:

您的.py 文件的程序关联可能被弄乱了。只需将 .py 文件与您的 python 可执行文件重新关联即可。

右击.py文件>Open with>Choose default program ...>[查找C:\PythonXY\python.exe]

【讨论】:

在我的系统上不起作用,因为它总是默认调用 Python 3.6。 selected answer 确实有效 从Windows10开始出现问题,所以这并不总是有效。【参考方案8】:

为了让它对我有用,我不得不使用注册表路径:

HKEY_CLASSES_ROOT\py_auto_file\shell\open\command

并添加了%*

【讨论】:

【参考方案9】:

我的设置位于另一个注册表项HKEY_CLASSES_ROOT\py_auto_file 下。提到的其他键也存在,但 Windows 出于某种原因正在使用这个键。

【讨论】:

【参考方案10】:

对于 Windows 7 上的 Python 3.3,我的设置在另一个注册表项下;我改变以使参数通过的关键是

HKEY_USERS\S-1-5-21-3922133726-554333396-2662258059-1000_Classes\py_auto_file\shell\open\command

它是"C:\Python\Python33\python.exe" "%1"。我只在它后面附加了%*。键的值现在是"C:\Python\Python33\python.exe" "%1" %*

我还有几个(至少五个)值为 "C:\Python\Python33\python.exe" "%1" 的其他键,但这是我更改的让它工作的那个。

【讨论】:

【参考方案11】:

我想我解决了这个问题。出于某种原因,注册表中有第二个位置(除了存储在 HKEY_CLASSES_ROOT\Python.File\shell\open\command 中的文件关联显示的位置):

[HKEY_CLASSES_ROOT\Applications\python.exe\shell\open\command]
@="\"C:\\Python25\\python.exe\" \"%1\" %*"

这似乎是我系统上的控制设置。上面的注册表设置添加了“%*”以将所有参数传递给 python.exe(由于某种原因,它在我的注册表中丢失了)。

【讨论】:

我的密钥在 Windows 7 上位于此处:HKEY_USERS\S-1-5-21-2829634124-923609355-2255922086-1001\Software\Classes\Applications\python.exe\shell\open\command 带值:C:\Python26\python.exe %1 %* 为我工作,请记住 mckoss 的答案是转义的,或者如果您正在编辑值,则 .REG 文件直接删除了那里的转义 附带说明:其根本原因可能是由于在 Python 安装之前与 .py 文件的初始文件关联。刚遇到这个问题,.py 类型的文件已经与记事本相关联,然后安装了 Python,这个丑陋的问题抬头。顺便说一句,在 Windows 10 上。 最近将启动器改成使用C:\Windows\py.exe,遇到了这个bug。但是,我修改了@StevenKeith 版本中的密钥,用“py.exe”替换了“python.exe”【参考方案12】:

有趣。使用 python 2.6 和 Windows XP (5.1.2600) 在这里工作:

C:\Documents and Settings\hbrown>python test.py foo
['test.py', 'foo']

C:\Documents and Settings\hbrown>test.py foo
['C:\\Documents and Settings\\hbrown\\test.py', 'foo']

C:\Documents and Settings\hbrown>test foo
['C:\\Documents and Settings\\hbrown\\test.py', 'foo']

C:\Documents and Settings\hbrown>type test.py
import sys
print sys.argv 

C:\Documents and Settings\hbrown>echo %PATHEXT%
.COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH;.PY 

C:\Documents and Settings\hbrown>assoc .py
.py=Python.File

【讨论】:

以上是关于Windows 没有将命令行参数传递给从 shell 执行的 Python 程序的主要内容,如果未能解决你的问题,请参考以下文章

有没有办法将命令行参数传递给自定义入口点(C / C ++)

将命令行参数传递给 python-behave

Wix Burn 没有将命令行参数传递给相关软件包(同一安装程序的旧版本)

如何将命令行参数传递给 c 程序

将命令行参数传递给 QPython

将命令行参数传递给在 Docker 中运行的 Java 应用程序(Spring Boot)