Python中模块(模块)和包(包)的区别

  
1。模块(模块)
  

在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护。

  

为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,很多编程语言都采用这种组织代码的方式,在Python中,一个<代码> . py 文件就称之为一个模块(模块)

  

<强>使用模块有什么好处?

  

最大的好处是大大提高了代码的可维护性。其次,编写代码不必从零开始。当一个模块编写完毕,就可以被其他地方引用。我们在编写程序的时候,也经常引用其他模块,包括Python内置的模块和来自第三方的模块。

  

使用模块还可以避免函数名和变量名冲突。相同名字的函数和变量完全可以分别存在不同的模块中,因此,我们自己在编写模块时,不必考虑名字会与其他模块冲突。但是也要注意,尽量不要与内置函数名字冲突。

  

你也许还想的到,如果不同的人编写的模块名相同怎么办?为了避免模块名冲突,Python又引入了按目录来组织模块的方法,称为包(包)

  

举个例子,一个<代码> abc.py> 的模块,一个<代码> xyz.py> xyz>   

现在,假设我们的abc <代码> 和<代码> xyz 这两个模块名字与其他模块冲突了,于是我们可以通过包来组织模块,避免冲突。方法是选择一个顶层包名,比如<代码> mycompany>   

 <代码> mycompany
  ├─__init__ . py
  ├─abc.py
  └─xyz.py  
  

?引入了包以后,只要顶层的包名不与别人冲突,那所有模块都不会与别人冲突。现在,<代码> abc.py 模块的名字就变成了<代码> mycompany.abc> xyz.py> mycompany.xyz>   

请注意,每一个包目录下面都会有一个<代码> __init__ . py> __init__ . py> __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模块的标准文件模板,当然也可以全部删掉不写,但是,按标准办事肯定没错。

  

后面开始就是真正的代码部分。

Python中模块(模块)和包(包)的区别