PYTHONPATH 是一个环境变量,其值为目录列表。设置后,Python 将使用它来搜索导入的模块以及其他标准。和 Python 的“sys.path”中列出的第 3 方库目录。
与任何其他环境变量一样,您可以将其导出到 shell 或 ~/.bashrc 中,请参阅 here。
您可以在 Python 中查询 os.environ['PYTHONPATH'] 的值,如下所示:
$ python3 -c "import os, sys; print(os.environ['PYTHONPATH']); print(sys.path) if 'PYTHONPATH' in sorted(os.environ) else print('PYTHONPATH is not defined')"
如果在 shell 中定义为
$ export PYTHONPATH=$HOME/Documents/DjangoTutorial/mysite
那么结果 =>
/home/Documents/DjangoTutorial/mysite
['', '/home/Documents/DjangoTutorial/mysite', '/usr/local/lib/python37.zip', '/usr/local/lib/python3.7', '/usr/local/lib/python3.7/lib-dynload', '/usr/local/lib/python3.7/site-packages']
ELSE 结果 =>
PYTHONPATH is not defined
要将 PYTHONPATH 设置为多个路径,请参阅 here。
请注意,可以在运行时通过 sys.path.insert()、del 或 remove() 添加或删除搜索路径,但不能通过 os.environ[]。
示例:
>>> os.environ['PYTHONPATH']="$HOME/Documents/DjangoTutorial/mysite"
>>> 'PYTHONPATH' in sorted(os.environ)
True
>>> sys.path // but Not there
['', '/usr/local/lib/python37.zip', '/usr/local/lib/python3.7', '/usr/local/lib/python3.7/lib-dynload', '/usr/local/lib/python3.7/site-packages']
>>> sys.path.insert(0,os.environ['PYTHONPATH'])
>>> sys.path // It's there
['$HOME/Documents/DjangoTutorial/mysite', '', '/usr/local/lib/python37.zip', '/usr/local/lib/python3.7', '/usr/local/lib/python3.7/lib-dynload', '/usr/local/lib/python3.7/site-packages']
>>>
总之,PYTHONPATH 是在 sys.path 中为导入的模块指定 Python 搜索路径的一种方式。您还可以在没有 PYTHONPATH 的帮助下直接将列表操作应用于 sys.path。