1、模块简介html
在实际开发中咱们不可能不用到系统的标准模块,或第三方模块。 若是想实现与时间有关的功能,就须要调用系统的time模块。若是想实现与文件和文件夹有关的操做,就须要要用到os模块。python
每个 Python 脚本文件均可以被当成是一个模块。模块以磁盘文件的形式存在。当一个模块变得过大,而且驱动了太多功能的话,就应该考虑拆一些代码出来另外建一个模块。模块里的代码能够是一段直接执行的脚本,也能够是一堆相似库函数的代码,从而能够被别的模块导 入(import)调用。模块能够包含直接运行的代码块、类定义、 函数定义或这几者的组合。 app
推荐全部的模块在Python模块的开头部分导入。并且最好按照这样的顺序:函数
Python标准库模块spa
Python第三方模块操作系统
应用程序自定义模块设计
import关键字code
在Python中用关键字import来引入某个模块,好比要导入模块time,就能够在文件最开始的地方用import time来引入xml
import module1 htm
import module2[
......
import moduleN]
或者:import module1[, module2[,... moduleN]]
在调用模块中的函数时,必须加上模块名调用,由于可能存在多个模块中含有相同名称的函数,此时,若是只是经过函数名来调用,解释器没法知道到底要调用哪一个函数。为了不这样的状况,调用函数时,必须加上模块名.
如:模块名.函数名
from…import
Python的from语句让你从模块中导入一个指定的部分到当前命名空间中。
如:from modname import name1[, name2[, ... nameN]]
要导入模块time的sleep函数,使用以下语句
from time import sleep
使用这种方式导入,不会整个模块导入到当前命名空间,它只会将import的内容导入。
from…import *
导入一个模块的全部内容也可使用from…import*。
如:from modname import*
扩展import语句(as)
有时候你导入的模块名称已经在你的程序中使用了, 或者你不想使用现有的名称。可使用一个新的名称替换原始的名称。。
如:import pandas #原始的名称
import pandas as pd #使用as从新命名
''' import 模块名 导入整个模块 经过模块名.方法名 调用 ''' # import time # print('start') # time.sleep(5) # print('stop') ''' from 模块名 import 函数名 从指定的模块中导入指定的部分 ''' # from time import sleep # print('start') # sleep(5) # print('stop') #导入模块中的全部内容 # from math import * # print(ceil(1.1))#向上取整 # print(floor(1.1)) #给导入的模块取别名 # import math as m # print(m.ceil(1.2)) # print(m.floor(1.2)) # from math import ceil as c #不建议使用 # print(c(1.2))
2、模块制做
跨目录模块调用
若是调用文件与被调用文件在一个目录下面,则能够很是方便地调用。那么若是被调用的文件与调用文件不在同一目录下的调用
定位模块1
当你导入一个模块,Python解析器对模块位置的搜索顺序是:
1.当前目录
2.若是不在当前目录,Python则搜索在环境变量PYTHONPATH下的每一个目录
3.若是都找不到,Python会察看默认路径。UNIX下,默认路径通常为/usr/local/lib/python/
4.模块搜索路径存储在system模块的sys.path变量中。变量里包含当前目录,PYTHONPATH和由安装过程决定的默认目录。
(sys模块用于提供对python解释器的相关操做。)
定位模块2
因此若是当前路径或 PythonPATH中存在与标准module一样的module,则会覆盖标准module。也就是说,若是当前目录下存在xml.py,那么在执行import xml时,导入的是当前目录下的module,而不是系统标准的xml.py。
''' 自定义模块 ''' # import test #引入同级目录中的test模块 # print(test.test_add(2,3)) # from test import test_add # print(test_add(2,3)) ''' 跨模块引入 ''' # import study.test2 #模块名.函数名 # print(study.test2.test2_add(2,3)) # from study import test2 # print(test2.test2_add(2,3)) # from study.test2 import test2_add # print(test2_add(2,3)) ''' 跨模块引入2 ''' # import sys #查看路径变量 # print(sys.path) #添加目标路径 到当前环境中(重点) # sys.path.append('..\\') #返回上一级目录 # print(sys.path) # import msg.send # msg.send.sendMsg() # from msg import send,recv # send.sendMsg() # recv.recvMsg() # from msg import math #引入自定义的模块 # print(math.ceil(1.2)) # print(math.floor(1.2)) # math.getInfo() #覆盖了标准模块
3、dir()函数与标准模块
dir()函数一个排好序的字符串列表,内容是一个模块里定义过的名字。 返回的列表容纳了在一个模块里定义的全部模块,变量和函数。
查看:dir(list)
标准模块
Python 自己带着一些标准的模块库,可参考 http://www.cnblogs.com/ribavnu/p/4886472.html
有些模块直接被构建在解析器里,这些虽然不是一些语言内置的功能,可是他却能很高效的使用,甚至是系统级调用也没问题。这些组件会根据不一样的操做系统进行不一样形式的配置,好比 winreg (Windows注册表访问)这个模块就只会提供给 Windows 系统。应该注意到这有一个特别的模块 sys ,它内置在每个 Python 解析器中。
4、包
包是一种管理 Python 模块命名空间的形式,采用"点模块名称"。好比一个模块的名称是 A.B, 那么他表示一个包 A中的子模块B
目录中只有包含一个叫作__init__.py的文件才会被认做是一个包
在导入包的时候,Python会从sys.path中的目录来寻找这个包中包含的子目录
模块在包里
导入包
现有两个模块功能有些联系,因此将其放到同一个文件夹下,一个文件中的类继承另外一个问文件中的类。
使用import文件.模块的方式导入
import recvmsg
recvmsg.add()
使用from文件夹import模块的方式导入
from recvmsg import *
add()
注意:必须包含__init__.py文件,才被认做是一个包
建立__init__.py
目录中只有包含了叫作__init__.py的文件,才能被程序认做是包,模块才能被导入成功。如今咱们就在msg文件夹下建立一个__init__.py文件,而且必定要在文件中写入__all__
__init__.py 控制着包的导入行为。若是__init__.py文件为空的话,仅仅是把这个包导入,不会导入包中的模块。__init__.py中的__all__变量,是用来控制from包名import * 时导入的模块。
能够在__init__.py中编写其余内容,在导入时,这些编写的内容就会被执行。
能够在__init__.py中向sys.path添加当前被调用模块路径。
__all__总结
1.编写Python代码(不建议在__init__中写python模块,能够在包中在建立另外的模块来写,尽可能保证__init__.py简单)
2.模块中不使用__all__属性,则导入模块内的全部公有属性,方法和类 。 模块中使用__all__属性,则表示只导入__all__中指定的属性,所以,使用__all__能够隐藏不想被import的默认值。 __all__变量是一个由string元素组成的list变量。 它定义了当咱们使用
3.from <module> import * 导入某个模块的时候能导出的符号(这里表明变量,函数,类等)。 from <module> import * 默认的行为是从给定的命名空间导出全部的符号(固然下划线开头的变量,方法和类除外)。 须要注意的是 __all__ 只影响到了 from <module> import * 这种导入方式, 对于 from <module> import <member> 导入方式并无影响,仍然能够从外部导入。
建立__init__.py总结
包将有联系的模块组织在一个,即放到同一个文件夹下,而且在这个文件夹建立一个名字为__init__.py文件,那么这个文件夹就称之为包
有效避免模块名称冲突问题,让应用组织结构更加清晰
imp.reload()简介
默认状况下,模块在第一次被导入以后,其余的导入都再也不有效。若是此时在另外一个窗口中改变并保存了模块的源代码文件,也没法更新该模块。这样设计缘由在于,导入是一个开销很大的操做(导入必须找到文件,将其编译成字节码,而且运行代码),以致于每一个文件、每一个程序运行不可以重复多于一次。
当一个模块被导入到一个脚本,模块顶层部分的代码只会被执行一次。 所以,若是你想从新执行模块里顶层部分的代码,能够用reload()函数。该函数会从新导入以前导入过的模块。
语法以下: reload(module_name)
''' dir函数 查看模块信息 ''' # print(dir()) # print(dir(math)) ''' python中的包 目录里面必须含有 __init__.py ''' #经过import方法 逐个导入模块 # import msg.send # msg.send.sendMsg() # import msg.recv # msg.recv.recvMsg() #经过from 一次性导入全部的模块 #作一个包必定要建立一个__init__.py 里面__all__指定容许被导入的包 # from msg import * # send.sendMsg() # recv.recvMsg() ''' 从新加载 ''' import test import imp imp.reload(test)
__init__.py文件
__all__ = ['send','recv']#容许被导入的模块
recv.py
def recvMsg(): print('成功接收消息')
send.py
def sendMsg(): print('消息发送成功')
test.py
def test_add(x,y): return x + y print('哈哈你被我骗了')
test2.py
def test2_add(x,y): return x + y