01 模块的概念
模块是python程序架构的一个核心概念

  • 每一个以扩展名 py 结尾的 python 源代码文件都是一个模块
  • 模块名 同样也是一个标识符,模块名 就是文件名,不能以数字开头(以数字开头 是无法在pycharm中通过导入这个模块的)
  • 模块就好比是工具包,在模块中定义的全局变量、函数、类 都是提供给外界直接使用的工具。要想使用这个工具包中的工具,首先需要导入这个模块

02 模块的两种导入方式
第一种:一次性把模块中所有工具导入

  • 在导入模块时,根据规范,每个导入代码应该独占一行
    如果模块名字太长,可以使用 as 指定模块的名称,以方便在代码中的使用(模块别名应该符合大驼峰命名规则)

    import lyy_04_测试模块1 as CatClass
  • 导入之后通过 模块名. 使用 模块提供的工具——全局变量、函数、类

第二种:

  • 如果希望从某一个模块中,导入部分工具,而不是将整个模块全部导入,可以使用

    from 模块名1 import 工具名
  • 导入之后 直接调用模块提供的工具(不需要通过模块名.调用 ,会报错)

  • 注意:若两个模块,存在同名函数,那么后导入模块的函数,会覆盖掉先导入的函数
    解决: 开发时 import 代码应该统一写在代码顶部,这样能及时发现冲突,一旦发现冲突,可以使用 as 关键字给其中一个工具起一个别名,然后直接调用就可以了

03 模块的搜索顺序【扩展】

  • python 解释器在导入模块时,会:
    首先搜索 当前目录 指定模块名的文件,如果有 就直接导入;
    如果没有再搜索 系统目录
  • 因此在开发时,给文件起名时,不要和系统的模块文件重名 (否则解释器就会加载当前目录下的 name.py 文件,而不会加载系统的 name.py 模块)
  • python 中每一个模块都有一个内置属性_ file__可以查看模块的完整路径
    (print name.
    _file__)

05 原则——每一个文件都应该是可以被导入的

  • 在导入文件时,文件中所有没有任何缩进的代码 都会被执行一遍!
  • 但是我们只需要模块中的 全局变量、函数、类这些工具,而直接执行的代码不是向外界提供的工具。
  • 实际的开发场景:
    实际开发中,每一个模块都是独立开放的,大多由专人负责
    开发人员通常会在模块下方 增加一些测试代码。但这些测试代码仅需要在模块内使用,而不需要被导入到文件中执行。

解决(非常固定)

  • _ _name__属性可以做到,测试模块的代码 只在测试情况下被运行,而在被导入时不会执行!
  • _ _name__属性是python的一个内置属性,记录着一个字符串
  • 如果是被其他文件导入时,_ _name__就是模块名
  • 如果是当前执行的程序,_ name__就是 main_
    在很多python文件中都会看到以下格式的代码: