1。模块(模块)
在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护。
为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,很多编程语言都采用这种组织代码的方式,在Python中,一个<代码> . py 代码>文件就称之为一个模块(模块)。
<强>使用模块有什么好处? 强>
最大的好处是大大提高了代码的可维护性。其次,编写代码不必从零开始。当一个模块编写完毕,就可以被其他地方引用。我们在编写程序的时候,也经常引用其他模块,包括Python内置的模块和来自第三方的模块。
使用模块还可以避免函数名和变量名冲突。相同名字的函数和变量完全可以分别存在不同的模块中,因此,我们自己在编写模块时,不必考虑名字会与其他模块冲突。但是也要注意,尽量不要与内置函数名字冲突。
你也许还想的到,如果不同的人编写的模块名相同怎么办?为了避免模块名冲突,Python又引入了按目录来组织模块的方法,称为包(包)。
举个例子,一个<代码> abc.py> 代码的文件就是一个名字叫abc <代码> 代码>的模块,一个<代码> xyz.py> 代码的文件就是一个名字叫<代码> xyz> 代码的模块。
现在,假设我们的abc <代码> 代码>和<代码> xyz 代码>这两个模块名字与其他模块冲突了,于是我们可以通过包来组织模块,避免冲突。方法是选择一个顶层包名,比如<代码> mycompany> 代码,按照如下目录存放
<代码> mycompany ├─__init__ . py ├─abc.py └─xyz.py 代码>
?引入了包以后,只要顶层的包名不与别人冲突,那所有模块都不会与别人冲突。现在,<代码> abc.py 代码>模块的名字就变成了<代码> mycompany.abc> 代码,类似的,<代码> xyz.py> 代码的模块名变成了<代码> mycompany.xyz> 代码。
请注意,每一个包目录下面都会有一个<代码> __init__ . py> 代码的文件,这个文件是必须存在的,否则,Python就把这个目录当成普通目录,而不是一个包。<代码> __init__ . py> 代码可以是空文件,也可以有Python代码,因为<代码> __init__ . py 代码>本身就是一个模块,而它的模块名就是mycompany。
类似的,可以有多级目录,组成多级层次的包结构,比如如下的目录结构:
<代码> mycompany ├─网络 │├─__init__ . py │├─utils.py │└─www.py ├─__init__ . py ├─abc.py └─xyz.py 代码>
文件www.py <代码> 代码>的模块名就是<代码> mycompany.web.www 代码>
指出:自己创建模块时要注意命的名,不能和Python自带的模块名称冲突。例如,系统自带了sys模块,自己的模块就不可命名为sys.py,否则将无法导入系统自带的sys模块。
2。使用模块
Python本身就内置了很多非常有用的模块,只要安装完毕,这些模块就可以立刻使用。
我们以内建的<代码> sys 代码>模块为例,编写一个<代码>你好> 代码的模块:
<代码>” 遇到问题没人解答?小编创建了一个Python学习交流QQ群:857662006 寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书! “‘ #?usr/bin/env python3 # - * -编码:utf - 8 - * “测试模块” __author__='迈克尔·廖' 导入系统 def测试(): args=系统。argv # argv参数用列表存储命令行的所有参数 如果len (args)==1: #当列表长度为1时即只有一个参数时 print (“Hello, world !”) elif len (args)==2: #当命令行有两个参数时 打印(' % s,你好!' % args [1]) 其他: 打印('太多参数!”) if __name__==癬_main__”: 代码测试()>
第1行和第2行是标准注释,第1行注释可以让这个hello.py文件直接在Unix/Linux/Mac上运行,第2行注释表示. py文件本身使用标准utf - 8编码;
第4行是一个字符串,表示模块的文档注释,任何模块代码的第一个字符串都被视为模块的文档注释;
第6行使用<代码> __author__> 代码变量把作者写进去,这样当你公开源代码后别人就可以瞻仰你的大名;
以上就是Python模块的标准文件模板,当然也可以全部删掉不写,但是,按标准办事肯定没错。
后面开始就是真正的代码部分。