您的位置:

Python 中模块的定位和执行

在本文中,我们将讨论用户如何在 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 模块定义了两个函数:

  1. 运行模块()
  2. 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 模块的功能来定位模块并执行它们。