模块
模块本质上是python文件/脚本,增强代码的可维护性和重用性
cacl.py脚本
_name_,如果不是导入执行,结果为_main_;
_name_,如果是导入执行(例如在下面的test中),结果为脚本名称;(脚本名为cacl.py,脚本名称为cacl
port = 22
def Add(x,y):
return x + y
print __name__
if __name__ == "__main__": ###导入时不会执行下面的函数
print Add(2,3)
结果:
__main__
5
cacl_test.py
import cacl
print cacl.Add(1,2)
print cacl.port
结果:
cacl ###发现输出的结果为脚本的名字
3
22
我们可以发现我们导入cacl模块并没有运行print Add(2,3)
导入模块的3种方法
注意:python自带优化,导入模块时只会导入一次,如果想重新导入可以使用:reload(模块名)
(1)import 模块名:尽量优先使用,避免与现有的函数名或者变量名冲突
模块名.函数名( )
模块名.变量名
(2)from 模块名 import 函数/变量名:有节制的使用;容易跟现有的函数名或者变量名冲突
在cacl_test.py中:
假设Add在系统本身存在,就会造成冲突
from cacl import Add
print Add(2,3)
结果:
cacl
5
(3)from 模块名 import *:尽量避免使用,会污染命名空间
在cacl_test.py中:
from cacl import *
print Add(1,2)
结果:
cacl
3
sys模块:
import sys
import pprint
print sys.path ###sys.path获取指定模块搜索路径的字符串集合(打印为一行)
pprint.pprint(sys.path) ###分行打印
sys.argv:
在外部向程序内部传递参数
def test():
args = sys.argv
if len(args) == 1:
print 'Hello world'
elif len(args) == 2:
print 'Hello %s!' %args[1]
else:
print 'Too many arguments!'
print sys.argv[0]
print sys.argv[1]
if __name__ == '__main__':
test()
测试:
python sys.py aa
结果:
_sys.py
aa
Hello aa!
包
包:简单来说包就是目录,比目录多了一个_init_.py文件
导包时,import 包名[.包名…].模块名
包的作用:
如果不同的人编写的模块名相同怎么办?为了避免模块名冲突,Python 又引入了按目录来组织模块的方法,称为(Package)
建立一个Package下面建立一个PythonPackage取名为Package01(可以发现多了个文件_init_.py)和Package_test.py
Package01下的建立一个add.py
a = 1
def add(x, y):
return x + y
导入方法:
第一种:
Package_test.py:
import Package01.add
print Package01.add.add(1, 2)
print Package01.add.a
结果:
3
1
第二种:
Package_test.py:
from Package01 import add
print add.add(1, 2)
print add.a
结果:
3
1
第三种:
在Package01的_init_.py中:
import add
Package_test.py:
from Package01 import * ###实质上是执行Package01包里面__init__.py脚本
print add.add(1, 2)
print add.a
结果:
3
1