我有一个存放所有Django应用程序的目录(C:\My_Projects)。我想把这个目录添加到我的PYTHONPATH中,这样我就可以直接调用应用程序。

我试着添加C:\My_Projects\;从Windows GUI到我的Windows路径变量(我的计算机>属性>高级系统设置>环境变量)。但它仍然不读取coltrane模块并生成以下错误:

错误:没有名为coltrane的模块


当前回答

将Python和PythonPath添加到Windows环境:

打开浏览器。 在左侧导航树面板中右键单击“计算机”。 选择上下文菜单底部的“属性”。 选择“高级系统设置” 点击“环境变量…”的高级选项卡 在“系统变量”下: 添加 PY_HOME C: \ Python27 PYTHONPATH环境 % PY_HOME % \ Lib; % PY_HOME % \ dll; % PY_HOME % \ Lib \ lib-tk; C: \另一个库 附加 路径 % PY_HOME %, % PY_HOME % \ \脚本

其他回答

import sys
sys.path.append("path/to/Modules")
print sys.path

这将不会持续到重新启动或被翻译到其他文件。然而,如果你不想对你的系统做永久性的修改,这是很好的。

您可以通过命令提示符轻松地设置路径变量。

打开运行并写入cmd 在命令窗口中输入如下命令: 设置路径= % %路径;C: \ python36 按回车。 检查是否写python并输入。您将看到如图所示的python版本。

这个问题需要一个恰当的答案:

只需使用标准的包站点,它是为这项工作而设计的!

以下是我的答案(抄袭了我自己对同一主题问题的回答):


打开Python提示符并键入

>>> import site
>>> site.USER_SITE
'C:\\Users\\ojdo\\AppData\\Roaming\\Python\\Python37\\site-packages'
...

(或者,调用python -m site——user-site也有同样的效果。)

如果这个文件夹还不存在,创建它:

...
>>> import os
>>> os.makedirs(site.USER_SITE)
...

(或者,在Bash中,您喜欢的makedirs -p $的变体(python -m site——user-site)。)

在这个文件夹中创建一个包含FIND_MY_PACKAGES内容的文件sitecustomize.py(使用这个文件名,否则它将不起作用),可以手动创建,也可以使用以下代码。当然,您必须将C:\My_Projects更改为自定义导入位置的正确路径。

...
>>> FIND_MY_PACKAGES = """
import site
site.addsitedir(r'C:\My_Projects')
"""
>>> filename = os.path.join(site.USER_SITE, 'sitecustomize.py')
>>> with open(filename, 'w') as outfile:
...     print(FIND_MY_PACKAGES, file=outfile)

下次启动Python时,C:\My_Projects会出现在sys. exe文件中。路径,而不必触及系统范围的设置。额外的好处:上面的步骤在Linux上也适用!


为什么会这样?

来自标准库包站点的文档:

[然后]尝试导入一个名为sitecustomize的模块,该模块可以执行任意特定于站点的定制。[…]。

因此,如果你在PYTHONPATH的任何地方创建了一个名为sitecustomize的模块,包site将在Python启动时执行它。通过调用site。Addsitedir, sys。路径可以安全地扩展到您的喜欢。

只需将您的安装路径(例如C:\Python27\)附加到系统变量中的path变量。然后关闭并打开你的命令行,输入'python'。

你知道在窗户上什么对我很有效。

我的电脑>属性>高级系统设置>环境变量>

只需将路径添加为C:\Python27(或任何安装python的地方)

OR

然后在系统变量下创建一个名为PythonPath的新变量。在这个变量中我有C:\Python27\Lib;C:\Python27\ dll;C:\Python27\Lib\ Lib -tk;C:\other-folders-on- path

这是对我有效的最好方法,我在任何医生提供的文件中都没有发现。

编辑:对于那些无法得到它的人, 请添加

C: \ Python27;

随它去吧。否则它永远不会起作用。