模块:一个py文件就是一个模块
当代码越来越多的时候,将所有的代码放入一个.py文件中会显得难以维护。解决办法则是代码分拆入不同的.py文件中,形成不同模块,这样做还能使得同名变量互不影响,需要注意的是,模块名不应与系统内置函数重名。
可以通过下面的方式导入模块
import module1
import module2
import module3
import module1,module2,module3
这两种方式的效果是一样的,但是第一种可读性比第二种好,推荐按照下面的顺序导入模块,并且一般在文件首部导入所有的模块
导入模块,就可重用这些函数和变量。一般用module_name.fun_name,和module_name.var_name进行使用。这样的语义用法使模块看起来很像类或者名字空间,可将module_name 理解为名字限定符。模块名就是文件名去掉.py后缀。
导入模块中的属性
单行导入
from module import name1,name2,name3
多行导入
from module import name1,name2,\
name3
导入全部属性(由于容易覆盖当前名称空间中现有的名字,所以一般不推荐使用,适合模块中变量名很长并且变量很多的情况)
from module import *
如果你不想某个模块的属性被以上方法导入,可以给该属性名称前加一个下划线
包:一个文件夹就是一个包,一个包中有多个模块
不同的.py文件也可能同名,这时候就可以考虑将其放入不同的文件夹中,形成不同的包,防止同名模块的影响。
区别包和文件夹的重要特征就是包文件夹内每一层目录都有初始化文件__init__.py!
__init__.py可以是空文件,也可以有Python代码,因为__init__.py本身就是一个模块,而它的模块名就是包的名称!所以导入一个包的时候,实际上导入的是这个包文件夹下面的__init__.py文件
一个带__init__.py的目录算一个包
可以这样导入:
from app.a import a
from app.b.b import test
a.test()
test()
上面代码表示:导入app包的子包a和子包b的属性test,然后分别调用test方法。
python默认是使用ASCII编码,可以指定编码方式,如
#!/usr/bin/env python
#coding=utf-8
或者
#!/usr/bin/env python
# -*- coding:utf-8 -*-
4. 解决导入循环问题有下面两个模块,a.py和b.py
a.py
#!/usr/bin/env python
#coding=utf-8
import b
if __name__ == '__main':
print 'hello,I'm a'
1b.py
#!/usr/bin/env python
#coding=utf-8
import a
if __name__ == '__main':
print 'hello,I'm b'
在这里a尝试导入b,而b也尝试导入a,导入一个先前没有完全导入的模块,会导致导入失败。解决办法:移除一个导入语句,把导入语句放到函数内部,在需要的时候导入。
b.py
#!/usr/bin/env python
#coding=utf-8
if __name__ == '__main':
import a
print 'hello,I'm b'