先盗张图_(:зゝ∠)_
模块
py中的模块类似其他语言中的头文件。我们可以把一些主题相关的函数和类放在一个模块里,这为py增加了许多可拓展性。
导入一个模块
我们先来导入一个模块,最开始py有一个内置的模块sys
import sys
我们通过‘.’来访问sys模块里的变量,函数或类。
sys.platform
'win32'
sys是system的缩写,其内部储存的往往是系统相关的信息,而其中的platform表示当前的系统平台。
创建一个模块
我们来写一个模块
def p():
print("a")
把上面的代码写入文件A.py中,然后尝试导入它
>>> import A
Traceback (most recent call last):
File "<pyshell#46>", line 1, in <module>
import A
ImportError: No module named 'A'
很显然,py无法找到被我们’随便’放置的文件。
这是因为py维护了一个默认的目录,py只会在这些目录下查找文件。sys的path变量会告诉我们默认目录的位置:(需要导入sys模块)
>>> print(sys.path)
['', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32\\Lib\\idlelib', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32\\python35.zip', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32\\DLLs', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32\\lib', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32', 'C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Python35-32\\lib\\site-packages']
然后随便选一个目录,把我们的A.py放进去就可以了。
>>> import A
>>> A.p()
a
我们也可以添加新的默认目录
sys.path.append("C:\\Users\\Administrator\\Desktop")
导入模块中的一部分
我们可以看到在导入模块后,我们要通过模块名来对模块内的东西进行访问,那么如果模块内的某个函数的使用频率非常高的话,每次使用都要多打一个模块名是非常不方便的,好在我们可以把那个函数单独从模块中导出:
>>> from A import p
>>> p()
a
或者使用*号导入全部
>>> from A import *
>>> p()
a
导入了模块的一部分后任然可以导入整个模块
>>> from A import p
>>> import A
>>> p()
a
>>> a.p()
a
导入时为目标重命名
使用as来改变名称:
import A as C
from A import p as print
导入同名函数的情况
有时候在两个模块里会出现两个同名的函数(或变量,类),如果我们先后导入这两个函数,那么后导入的会覆盖先导入的:
写一个新的模块B
def p():
print("b")
使用情况:
>>> from A import p
>>> p()
a
>>> from B import p
>>> p()
b
包
一般来讲,一个模块通常只储存一个类,那么出现多个相关类的情况时,我们就可以创建一个包来进行管理,包与操作系统的目录结构类似。
创建一个包
首先在py的默认目录下创建一个文件夹kit。然后在kit里创建两个文件A.py和B.py
A.py
def printA():
print("a")
B.py
def printB():
print("b")
然后相当重要的一点,在目录下新建一个__init__.py文件。这个文件提示python这个是一个包目录,当导入包时,__init__文件首先被计算,它指定了要使用的文件及方式:
__init__.py
from .A import *
from .A import *
之后在我们的程序里导入kit模块就可以了
>>> import kit
>>> kit.printA()
a
__all__
之前提到使用from … import 来显式的导入名称。现在我们可以在__init__中决定from … import 所导入的部分。
修改__init__.py
from .A import *
from .B import *
__all__ = ["printA"]
然后导入kit模块:
>>> from kit import *
>>> printA()
a
>>> printB()
Traceback (most recent call last):
File "<pyshell#40>", line 1, in <module>
printB()
NameError: name 'printB' is not defined
虽然通过*号导入了全部,但我们真正能使用的还是只有__all__列表中所保存的函数。
__name__
py中的__name__会告诉我们程序中正在运行的作用域名称。
>>> __name__
'__main__'
保留字__main__是顶层全局作用域的名称。
如果我们修改之前kit的__init__文件:
from .A import *
from .B import *
__all__ = ["printA"]
print(__name__)
那么在导入时:
>>> import kit
kit
所以
1. 如果模块是被导入,__name__的值为模块名字
2. 如果模块是被直接执行,__name__的值为’__main__’
我们可以在写模块时使用:
if __name__ == '__main__'
来进行测试,如果是在写模块的过程中,那么这句if语句就会被执行,而在模块被调用的过程中就不会执行。