一,复习

'''
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.导模块的细节
2.包的概念与使用
3.包中的相对导入语法
4.项目开发规范
5.logging
'''

'''
常用模块
os,sys,time
json ******,pickle
re(正则) ******
'''

 

三,跨文件夹导入模块

# 1.如果a文件夹所在目录在环境变量,a文件夹中的ma模块可以被以下方式导入
import a.ma  |  from a import ma 

# 2.如果a文件夹所在目录在环境变量,a文件夹中的b文件夹的mb模块可以被以下方式导入
import a.b.mb  |  from a.b import mb

# 3.如果a文件夹所在目录在环境变量,a文件夹中的b文件夹的mb模块中的bbb名字要被直接导入 
import a.b.mb.bbb  # 错误:所有.左侧必须是文件夹 *****
from a.b import mb.bbb # 错误:所有.左侧必须是文件夹
from a.b.mb import bbb # 正确

 

四,模块的两种被执行方式

# 总结: 
# 1.一个py文件作为自执行文件,__name__变量的值为 '__main__'
# 2.一个py文件作为模块被导入执行,__name__变量的值为 '文件(模块)名'


# 如何区别两种方式,可以让一个文件可以自执行,也可以被导入执行 共存
# 在这样的py文件中写:
if __name__ == '__main__':
    # 自执行的逻辑 => 因为在文件作为模块使用时 __name__为文件名,不满足条件
    pass

 

五,包

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


# 包 与 普通文件夹存在区别:包的文件夹中一定存在一个__init__.py文件
#        -- py2:必须创建  py3:建议创建,不创建系统会自动创建


# __init__.py文件
# 1)产生一个全局名称空间,提供给包的,就代表包的名称空间
# 2)管理 包可以直接点出来使用的 名字


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

 

六,直接使用包中模块

# 如果只是想作为普通文件夹,py3中可以省略__init__文件,本质上文件夹也是包

# 导入的手段:
# 1,指名道姓到某一个模块
  from mp import m1
  print(m1.aaa) #1000

#2,指名道姓到某一个模块中的名字
  from mp.m1 import aaa
  print(aaa)

 

七,包的管理

# 在包中采用相对导入管理模块或模块中的名字

# 在包的__init__.py文件或是包中任意一个模块中
# . 代表当前文件所在目录
# .. 代表当前文件所在目录的上一级目录

# 注:.语法不能出包,因为包外的文件都能自执行,但拥有.开头导入的文件不能自执行

#.语法开头的文件不能作为自执行文件

from .s1 import sss
from ..m1 import a,b,c

 

总结

# 包的概念?
  一系列模块的集合体,该文件夹称为包,文件夹名为包名,有__init__文件的就是包,没有__init__文件为普通文件!
# 一定要有包吗?
  ——如果指名道姓到具体模块或模块名,就不需要包,py3环境下,在py2必须要有__init__文件
# 在__init__中怎么管理包中的名字?
  ——通过相对导入进行管理
  ——.代表当前文件所在目录
  ——..代表当前文件所在目录的上一级目录



#__init__文件:
# import m1  #错误,m1所在路径mp不在环境变量中

''''#报错,语法上不满足'''''
# import .m1

'''
这两种都行,在包内指名道姓都不会出问题,进入__init__文件后绝对导入都不会在依赖于环境变量
'''
# import mp.m1
# from mp import m1


'''外界导包,内部在init文件中 from .import 具体内容,
这个点就是D:\\Python_Project\\ClassRoom\\day17(包)\\part4\\mp'''
# from . import m1 => from D:\\Python_Project\\ClassRoom\\day17(包)\\part4\\mp import m1
# 在t1文件中导入mp,会直接进入init中会接着进入.后面的语句去导m1

from . import m1
from .m1 import a,b,c

 

# from a import ma
# print(ma)
# from b.c import mc
# print(mc)
#
# # from b import x.mc  # 不合法
# # print(x.mc)
#
# import b.c.mc as mc
# print(mc)



import x
# print(x.mx.xxx) 
# print(x.xxx)
#
# # x.yyy => x.init [ from .y.my import yyy ]
# print(x.yyy)
#
# # x.my.yyy => x.init [ from .y import my ]
# print(x.my.yyy)
#
# # x.y.yyy => x.init [ from . import y ] | y.init [ from .my import yyy ]
# print(x.y.yyy)

# x.y.my.yyy => x.init [ from . import y ] | y.init [ from . import my ]
print(x.y.my)

# 总结:
# 1.什么时候要使用包的init文件 - 出现了导包语法 import x,代表要访问x包的名称空间
# 2.不管父包还是子包能直接.出来的名字,一定在该包的init文件中进行管理

# eg:在x.init文件 from .y.my import yyy => x.yyy | x.y | x.y.my | x.y.my.yyy都好使
# 3.了了解:一旦一条完整路径走完,通过完整路径的语法使用名字都是合法的

 

posted on 2019-05-06 16:56  Jolinhe  阅读(257)  评论(0编辑  收藏  举报