• python学习Day17 五项【导模块的细节:(跨文件导入模块 &模块的两种执行方式) | 包的概念与使用 | 包中的相对导入语法】


    复习

    1.模块
    -- 一系列功能的集合体,用文件来管理一系列有联系的功能,该文件我们称之为模块,文件名就是模块名
    -- import | from...import 来导入模块,从而使用模块中的功能
    -- py文件 | 管理py文件的包 | c编译的内置模块 | c、C++通过的DLL拓展
    -- 内置模块 | 自定义模块

    2.导入模块完成的三件事
    1)编译产生模块对应的pyc文件
    2)执行模块中的代码,形成模块的全局名称空间,将模块中的名字存放在该模块的全局名称空间中
    3)在到模块的文件中,形成一个与模块名同名的名字,指向模块的全局名称空间

    3.起别名:原名失效

    4.自定义模块:系统 | 第三方 | 自己

    5.加载顺序:内存 -> 内置 -> sys.path
    -- 所有能被导入的模块,一定在sys.path存放的路径中可以找到

    6.环境变量sys.path:存放路径的list,可以任意操作,但默认第一个成员一定是当前执行文件所有的目录

    7.from...import a as m_a, b as m_b | from...import * (__all__ = ['a', 'b'])

    8.import | from...import 采用的是依赖sys.path的绝对导入

    9.链式导入 => 循环导入
    -- 问题:使用名字在产生名字之前,导入模块过早
    -- 解决:将导入模块的逻辑放在产生名字之后,延迟导入

    今日内容 :导模块的细节(跨文件导入模块 | 模块的两种执行方式)|   包的概念与使用   |    包中的相对导入语法

    一、导模块的细节 :

           1.跨文件夹导入模块:所有.的左侧必须是文件夹, import 必须到到文件,不能多导,也不能少导,点点太多可以as 别名

             

        2. 模块的两种执行方式:①自执行    ②被导入者执行

           想要让一个文件可以直接自执行,也可以在被导入时不马上执行,共存

           在该.py文件中写:if __name__ == '__main__' :   run()

                                        自执行的逻辑 =>  因为在文件作为模块被导入时,__name__变量的值默认为 ’__该文件(模块)名__'   不满足if 条件。

         ①一个py文件作为自执行文件,内置__name__变量的值默认为 ’__main__' 

         ② 该py文件作为模块被导入执行,内置__name__变量的值默认为 ’__该文件(模块)名__' 

     二、包的概念:

     2.1  一系列模块的集合体,用文件夹来管理一系列有联系功能的模块,该文件夹我们称之为包,文件夹名就是包名

          

           包 与 普通文件夹存区别:包的文件夹中一定存在一个__init__.py文件:

            __init__.py文件 ①产生一个全局名称空间,代表包的名称空间;

                                      ②管理包中的模块,导包的时候直接通过__init__.py来管理,直接点出来使用的名字。
             -- py2:必须创建 py3:建议创建,不创建系统会自动创建

    2.2 包的使用

         导包完成的三件事
         1)编译形成包中__init__.py文件的pyc文件
         2)执行__init__.py文件,形成一个全局名称空间,将__init__.py文件中所有名字存放其中,该名称空间就代表包的名称空间
         3)在导包的文件中,产生一个与包名相同的名字,指向包的名称空间(__init__.py文件的全局名称空间)

         ① 直接使用包中模块

              作为普通文件,1.指名道姓到某一个模块   |     2.指名道姓到某一个模块中的名字

              py3中可以省略__init__文件, py2中一定要有_init_文件

         ②  包的管理 

              在包中/内部全都采用相对导入,管理模块或模块中的名字

             在包的管家__init__.py文件或是包中任意一个模块中

              . 代表当前文件所在目录
             .. 代表当前文件所在目录的上一级目录
            .语法不能出包,因为包外的文件都能自执行,但拥有.开头导入的文件不能自执行

    总结 :包的概念

                        包是什么?为什么要有包?一定要有包吗?在__init__中怎么管理包中的名字?

                       ①包就是一系列模块的集合体,将有联系的模块放在一个文件夹里,那这个文件夹就是包,文件夹名就是包名。包与普通文件夹的区别是,包中的模块文件由_init_.py文件来管理;

                                                                而普通文件夹没有_init_.py文件

                       使用包中的模块,可以通过包名找到包的管家_init_文件,进而找到想要的功能。所以明确包,就必须有_init_文件。

                       首先包不是必须的,py3中可以省略__init__文件,可以通过from...import 模块来指名道姓找到想要的模块,而py2必须要有_init_文件的包。

                       ④ 怎么直接通过包名使用包中的某一个模块?或者是直接通过包名使用包中的某个模块中的名字?

                            首先在执行文件T1中导入包名 import  mp,  

                            在_init_文件中必须要提供给包外界的T1对应的模块名,或者是模块中的名字。在init中用from .. 相对导入模块或模块的名字。from后面一定是站在执行文件的角度找模块,

                           也就是在执行文件所在的目录的基础上进行包中的相对导入。包的内部所有文件都用. | .. | ... 相对导入,包外部的调用都采用绝对导入。

                          ---不管是from ...  import 还是  imoprt只要是有具体的名字(文件夹)一定是绝对导入。

                         ----外界导包就相当于把包名放到了环境变量中,包内部init文件中就可以        from 包名  imoprt 具体内容 /  from .  import 具体内容,这个点就是包名。

                         ---- from . import m1  =>  from  F:python8期课堂内容day17part5ma   import  m1

                         ----   在包中from ... import 的from 关键字后直接出现的点代表从当前文件所在路径接着往下导

                         --  点开头的不能自执行

                     

  • 相关阅读:
    如何在 Microsoft Visual C# .NET 中实现 Microsoft Excel 自动化
    CentOS 6.5静态IP的设置(NAT和桥接都适用)
    myeclipse里如何添加mysql数据库
    Attribute value is quoted with " which must be escaped when used within the value 问题解决
    CentOS 6.5安装之后的网络配置
    Apache server for win解压版的安装与配置
    Oracle SQL 基本操作之 用户权限管理方法
    CentOS 6.5的安装详解
    IO类01
    可见性的问题
  • 原文地址:https://www.cnblogs.com/qingqinxu/p/10818512.html
Copyright © 2020-2023  润新知