Python入门之模块和包用法详解

2022-07-19 10:49:46
目录
模块1. 导入模块的方式2. 导入方式详解3. 制作模块4. 模块定位顺序5. __all__1. 制作包2. 导入包总结

模块

Python>

模块能定义函数,类和变量,模块里也能包含可执行的代码

1.>
    import 模块名from 模块名 import 功能名from 模块名 import *import 模块名 as 别名from 模块名 import 功能名 as 别名

    2.>

    import

    语法

    # 1. 导入模块
    import 模块名
    import 模块名1,模块名2
    
    # 2. 调用功能
    模块名.功能名()
    

    体验

    import math
    print(math.sqrt(9))  # 3.0
    

    from…import…

    语法

    from 模块名 import 功能1,功能2,功能3...

    体验

    from math import sqrt
    print(sqrt(9))
    

    from… import *

    语法

    from 模块名 import *

    体验

    from math import *
    print(sqrt(9))
    

    as定义别名

    语法

    # 模块定义别名
    import 模块名 as 别名
    
    ​​​​​​​# 功能定义别名
    from 模块名 import 功能 as 别名
    

    体验

    # 模块别名
    import time as tt
    
    tt.sleep(2)
    print('hello')
    
    # 功能别名
    from time import sleep as sl
    sl(2)
    print('hello')
    

    注意:定义别名后不能再使用原功能名

    3.>

    在 Python 中,每个 Python 文件都可以作为一个模块,模块的名字就是文件的名字,也就是说自定义模块名必须要符合标识符命名规则

    ① 定义模块

    新建一个 Python 文件,命名为 my_module1.py,并定义 testA 函数

    def testA(a, b):
        print(a + b)
    

    ② 测试模块

    在实际开发中,当一个开发人员编写完一个模块后,为了让模块能够在项目中达到想要的效果,这个开发人员会自行在 py 文件中添加一些测试信息,例如,在 my_module1.py 文件中添加以下测试代码

    def testA(a, b):
    	print(a + b)
    
    # 测试信息
    testA(1, 1)
    

    此时,无论是当前文件,还是其他已经导入了该模块的文件,在运行的时候都会自动执行 testA 函数的调用

    解决方法如下:

    def testA(a, b):
    	print(a + b)
    
    # 只在当前文件中调用该函数,其他导入的文件内不符合该条件,则不执行 testA 函数调用
    # __name__ 是系统变量,是模块的标识符,值是:如果是自身模块值的 __main__,否则的当前模块名字
    if __name__ == '__main__':
    	testA(1, 1)
    

    ③ 调用模块

    import my_module1
    my_module1.testA(2,4)
    

    4.>

    当导入一个模块,Python 解析器对模块位置的搜索顺序是:

      当前目录如果不在当前目录,Python 则搜索在 shell 变量 PYTHONPATH 下的每个目录如果都找不到,Python 会查看默认路径。UNIX 下,默认路径一半为 /usr/local/lib/python/

    模块搜索路径存储在 system 模块的 sys.path 变量中,变量里包含当前目录、PYTHONPATH 和由安装过程决定的默认目录

    注意

    ◦ 自己的文件名不要和已有模块名重复,否则导致模块功能无法使用

    ◦ 使用 from 模块名 import 功能 的时候,如果功能名字重复,调用到的是最后定义或导入的功能

    5.>

    如果一个模块文件由 __all__ 变量,当使用 from xx import * 导入时,只能导入这个列表中的元素

    my_module2 模块代码

    __all__ = ['testA']
    
    def testA():
    	print('testA')
    
    def testB():
    	print('testB')
    

    导入模块的文件代码

    from my_module2 import *
    testA()
    testB()
    

    包将有联系的模块组织在一起,即放到同一个文件夹下,并且在这个文件夹创建一个名字为>

    1.>

    [New] - [Python Package] - 输入包名 - [OK] - 新建功能模块(有联系的模块)

    注意:新建包后,包内部会自动创建 __init__.py 文件,这个文件控制着包的导入行为

    快速体验

      新建包 my_package新建包内模块:my_module1 和 my_module2模块内代码如下
      # my_module1
      print(1)
      
      
      def info_print1():
          print('my_module1')
      
      # my_module1
      print(2)
      
      
      def info_print2():
          print('my_module2')
      

      2.>

      方法一

      import 包名.模块名

      包名.模块名.目标

      体验

      import my_package.my_module1
      my_package.my_module1.info_print1()
      

      方法二

      注意:必须在 __init__.py 文件中添加 __all__ = [],控制允许导入的模块列表

      from 包名 import *
      模块名.目标

      体验

      from my_package import *
      my_module1.info_print1()
      

      总结

      导入模块方法

      import 模块名
      
      from 模块名 import 目标
      
      from 模块名 import *
      

      导入包

      import 包名.模块名
      
      from 包名 import *
      

      __all__ = []:允许导入的模块或功能列表

      以上就是Python入门之模块和包用法详解的详细内容,更多关于Python模块 包的资料请关注易采站长站其它相关文章!