在本文中,我们将讨论用户如何在 Python 中定位模块,以及使用 Python 的哪些功能来执行模块。
在 Python 中定位模块
当用户导入模块时,Python 解释器将在当前目录中搜索该模块。如果在目录中找不到该模块,解释器将搜索 Shell 变量(称为 PYTHONPATH)中的每个目录。如果解释器在 shell 中找不到它,那么它将检查默认路径。在 UNIX 中,这个默认路径是:/usr/local/lib/python/。
模块的搜索路径作为 sys.path 变量存储在sys
模块 sys 中。该变量包含当前目录,即 PYTHONPATH,以及依赖于安装的默认值。
PYTHONPATH 变量
PYTHONPATH 变量是一个基于平台的变量,由目录列表组成。它的语法与 shell 变量的 PATH 相同。
windows 系统中的 PYTHONPATH:
set PYTHONPATH = c: \\python3\\lib;
来自 UNIX 系统的 PYPTHONPATH
set PYTHONPATH = /usr/local/lib/python
用 Python 执行模块
从命令行选项中,-m 选项用于定位给定模块的路径,并且它作为程序的 main 模块执行该模块。runpy 模块是 Python 的标准模块,用于内部支持该机制。runpy 模块允许通过使用 Python 模块的命名空间而不是文件系统来定位脚本。
runpy 模块定义了两个函数:
- 运行模块()
- run_path()
运行模块()
run_module()函数用于执行包含特定模块的代码,它将返回模块全局字典的结果。
module_name 参数应该是实际的模块名称。假设模块的名称引用了任何包,而不是普通模块。在这种情况下,该包将被导入,包内的 main 子模块将被执行,并将返回模块全局字典的结果。
特殊的全局变量,即 name、spec、file、cached、loader 和 package ,是在执行模块之前在全局字典中设置的。
name 设置为 module_name +'。main ',如果命名的模块是包;否则,它将被设置为 module_name 参数。
和 file、 cached 、loader 和 package 根据模块规范设置为正常。
run_path()
run_path()函数用于在给定路径下执行文件中的程序,它将返回模块全局字典。给定的路径可以引用 Python 源文件、编译的字节码文件或包含 main 模块的有效 sys.path 条目,例如包含顶级 main 的 zip 文件。py 文件。
特殊的全局变量,即 name、spec、file、cached、loader 和 package ,是在执行模块之前在全局字典中设置的。
如果此可选参数不等于“无”,则 name 变量设置为 run _ name 否则,将设置为。
示例:
让我们看一个 runpy 模块的例子:
首先,用户必须将以下文件保存为名为 runpy_example.py 的脚本。
def add(p, q, r, s, t):
return p + q + r + s + t
def main():
p = 4
q = 6
r = 2
s = 8
t = 7
print ("sum of p, q, r, s, t = ")
print (add(p,q,r,s,t))
return
if __name__=='__main__':
main()
然后,用户将使用以下命令执行上述文件:
import runpy_example as runp
runp.main()
输出:
sum of p, q, r, s, t =
27
但是,用户可以在不导入的情况下执行上述文件:
import runpy
runpy.run_module('runpy_example', run_name='__main__')
输出:
sum of p, q, r, s, t =
27
用户还可以用户 run_path()函数:
runpy.run_path('runpy_example.py', run_name='__main__')
输出:
sum of p, q, r, s, t =
27
如前所述,runpy 还支持 Python 命令行的-m 开关:
C:\python37>python -m runpy_example
结论
在本文中,我们讨论了用户如何使用 Python 标准模块的 runpy 模块的功能来定位模块并执行它们。