关于python中的包,模块导入的问题详解(二)

  • from import导入

    紧接着的是from xx import xx  语法

    

 1 ################
 2 from my_moudule import name
 3 print(name)
 4 
 5 name='123'
 6 print(name)
 7 
 8 from my_module import name 
 9 print(name)
10 
11 
12 
13 from my_module import name,read1,read2  #导入模块中多个变量
14 
15 
16 from my_mosule import nam as n,read1 as r1,read2 as r2  #重命名
17 
18 ####---------星号的用法----------#####
19 from my_module import *   #导入模块中所有的名字
20 
21 
22 #在被导入模块中不希望被全部导入 可以定义一个参数名为__all__的参数列表
23 
24 __all__=['name','read1','read2']
25 
26 
27 #这样,即使当前模块导入了该模块所有的名字,也只能调用__all__列表中的名字
 

 

28 ########3---------------------------------------######
29 
30 
31 
32 
33 
34 
35 ################################
36 这种方式导入 的包调用时可以假象成在当前模块定义的变量,调用方便 
 
  • 二:pyc文件
pyc:当文件被当作模块调用时会自动产生pyc文件,python文件被编译后就得到pyc(二进制)文件,再次被调用时,就不用再次编译,直接引用,  

1 pyc文件的优点:
2         1,python为了提高运行效率也会进行编译,python是解释型语言,运行的时候需要通过python解释器编译,所以先编译出pyc文件后,可以节省编译这一步的耗时时间。
3 
4         2,不想让源码泄露,因为py文件是可以直接看到源码的,对于一般的商业公司来说,这有点不妙,因为pyc文件可以独立于py文件,删除py文件也不会出错。这就是太好了,只需要编译成pyc文件再发布出去就好了。
  •  三:模块的导入和修改
############
import file_1
print(file_1.name)
##修改源文件name
import file_1
print(file_1.name)  #####结果不会受影响,依旧是最开始的值,,



原因:import不会多次导入一个模块,即便有改动,也检测不到
非要强制修改可使用importlib模块中的reload方法

from importlib import reload


******
*****
**
reload(file_1)

*****
****
**
#结果就会更改了 不 要 经 常 用!!!!
  • 四:模块的循环使用 

 现有  A   B  两个文件,A引用了B ,B同时也引用了A,这就是循环引用,要避免这种设计

五:dir(模块)

dir(模块)  :可以获取到这个模块中所有的名字,可以使用反射的方法对元素进行操作,因为是以字符串形式返回的

 二:包的导入:

2.1、什么是包:

    含有一个__init__.py的文件夹就是一个包,包中通常含有一些py文件,一般包是给我们提供复杂功能的功能

   在python2中需要注意的是,如果建的文件选择的不是文件包,不会产生__init__.py文件,会出现导入不成功的错误!!!

手动建立这个文件就可以。导入包的过程中自动执行了__init__.py文件

2.2、从包当中导入模块

 1 #############从包中导入模块的两种方法
 2 
 3 同包当中导入模块
 4 
 5 ##########111111
 6 import
 7 
 8 #import  包.包.包.包.包.包.包.模块
 9 #最终是要精确到模块才行
10 
11 
12 
13 
14 
15 
16 
17 
18 from   import#####个人推荐
19 
20 from 包.包.包.包 import 模块    #把包和模块分离   且调用更方便
21 app.get()  #模块名.方法
22 from 包.包.包.包.包.模块  import 方法   #具体到模块以下,,直接调用方法
23 get()#直接方法名即可
2.3、导入包:

如图所示的导入,虽然能成功导入,却无法使用这个包中的模块或者工具集
原因是路径问题,
包导入的绝对(路径)导入:是我们在导入包需注意的一点,要以根节点为起点导入
    缺点:每次移动模块都需要重新修改路径
    优点:模块可以单独执行
 1 ######目录结构###
 2  2 
 3  3 ---/
 4  4     |
 5  5     |
 6  6     glance2——
 7  7     |               |
 8  8     |               |——__init__.py   ----->(from glance2 import api )    
 9  9     |               |
10 10    |                api——    
11 11    |                          |
12 12    |                          |——__init__.py--------->(from glance2.api  import policy)   
13 13    |                          |
14 14    |                          |——policy.py  ------->(def get(): print("123"))
15 15 
16 16 ######################glance3同级目录可调用
17 
18 import  glance2     #执行了glance2下的__init__.py文件
19 glance2.api      #找不到方法
20 
21 #报错  ,如上图所示
22 sys.path中的内容,永远是当前执行文件的路径
23 
24 按上图路径配置即可
25 
26 每个路径都明明白白写清楚,清晰看到目录结构,方便后续开发
 

包导入的相对(路径)导入:(.)表示当前目录,,(..)上级目录
    优点:
文件夹有移动也不会影响整个程序,只要能找到最相对根目录就可以导入
    缺点:只要带相对路径导入的模块,就无法单独执行,只能当作模块给别人提供服务
 
 1 ######目录结构###即使后面的开发工作中文件夹,,,文件夹有移动也不会影响整个程序
 2 
 3 ---/
 4     |
 5     |
 6     glance3——
 7                    |
 8                    |——__init__.py   ----->(from . import api)    #相对导入
 9                    |
10                    api——    
11                             |
12                             |——__init__.py--------->(from . iport policy)   #相对导入
13                             |
14                             |——policy.py  ------->(def get(): print("123"))
15 
16 ######################glance3同级目录可调用
17 import glance3
18 glance3.api.policy.get()
19             
20 
21 
22 123







猜你喜欢

转载自www.cnblogs.com/My-DreamTrip/p/11276424.html