Python 模塊和包的概念

模塊&包(* * * * *)

模塊(modue)的概念:

在計算機程序的開發過程當中,隨着程序代碼越寫越多,在一個文件裏代碼就會愈來愈長,愈來愈不容易維護。python

爲了編寫可維護的代碼,咱們把不少函數分組,分別放到不一樣的文件裏,這樣,每一個文件包含的代碼就相對較少,不少編程語言都採用這種組織代碼的方式。在Python中,一個.py文件就稱之爲一個模塊(Module)。linux

使用模塊有什麼好處?程序員

最大的好處是大大提升了代碼的可維護性。django

其次,編寫代碼沒必要從零開始。當一個模塊編寫完畢,就能夠被其餘地方引用。咱們在編寫程序的時候,也常常引用其餘模塊,包括Python內置的模塊和來自第三方的模塊。編程

因此,模塊一共三種:app

  • python標準庫
  • 第三方模塊
  • 應用程序自定義模塊

另外,使用模塊還能夠避免函數名和變量名衝突。相同名字的函數和變量徹底能夠分別存在不一樣的模塊中,所以,咱們本身在編寫模塊時,沒必要考慮名字會與其餘模塊衝突。可是也要注意,儘可能不要與內置函數名字衝突。編程語言

模塊導入方法

1 import 語句函數

1
import  module1[, module2[,... moduleN]

當咱們使用import語句的時候,Python解釋器是怎樣找到對應的文件的呢?答案就是解釋器有本身的搜索路徑,存在sys.path裏。  spa

1
2
[' ', ' / usr / lib / python3. 4 ', ' / usr / lib / python3. 4 / plat - x86_64 - linux - gnu',
'/usr/lib/python3.4/lib-dynload' '/usr/local/lib/python3.4/dist-packages' '/usr/lib/python3/dist-packages' ]  

所以若像我同樣在當前目錄下存在與要引入模塊同名的文件,就會把要引入的模塊屏蔽掉。命令行

2  from…import 語句

1
from  modname  import  name1[, name2[, ... nameN]]

這個聲明不會把整個modulename模塊導入到當前的命名空間中,只會將它裏面的name1或name2單個引入到執行這個聲明的模塊的全局符號表。

3  From…import* 語句

1
from  modname  import  *

這提供了一個簡單的方法來導入一個模塊中的全部項目。然而這種聲明不應被過多地使用。大多數狀況, Python程序員不使用這種方法,由於引入的其它來源的命名,極可能覆蓋了已有的定義。

4 運行本質 

1
2
#1 import test
#2 from test import add  

不管1仍是2,首先經過sys.path找到test.py,而後執行test腳本(所有執行),區別是1會將test這個變量名加載到名字空間,而2只會將add這個變量名加載進來。  

包(package)

若是不一樣的人編寫的模塊名相同怎麼辦?爲了不模塊名衝突,Python又引入了按目錄來組織模塊的方法,稱爲包(Package)。

舉個例子,一個abc.py的文件就是一個名字叫abc的模塊,一個xyz.py的文件就是一個名字叫xyz的模塊。

如今,假設咱們的abcxyz這兩個模塊名字與其餘模塊衝突了,因而咱們能夠經過包來組織模塊,避免衝突。方法是選擇一個頂層包名:

                                           

引入了包之後,只要頂層的包名不與別人衝突,那全部模塊都不會與別人衝突。如今,view.py模塊的名字就變成了hello_django.app01.views,相似的,manage.py的模塊名則是hello_django.manage。

請注意,每個包目錄下面都會有一個__init__.py的文件,這個文件是必須存在的,不然,Python就把這個目錄當成普通目錄(文件夾),而不是一個包。__init__.py能夠是空文件,也能夠有Python代碼,由於__init__.py自己就是一個模塊,而它的模塊名就是對應包的名字。

調用包就是執行包下的__init__.py文件

 注意點(important)

1--------------

在nod1裏import  hello是找不到的,有同窗說能夠找到呀,那是由於你的pycharm爲你把myapp這一層路徑加入到了sys.path裏面,因此能夠找到,然而程序一旦在命令行運行,則報錯。有同窗問那怎麼辦?簡單啊,本身把這個路徑加進去不就OK啦:

1
2
3
4
5
import  sys,os
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
sys.path.append(BASE_DIR)
import  hello
hello.hello1()

2 --------------

1
2
if  __name__ = = '__main__' :
     print ( 'ok' )

「Make a .py both importable and executable」

      若是咱們是直接執行某個.py文件的時候,該文件中那麼」__name__ == '__main__'「是True,可是咱們若是從另一個.py文件經過import導入該文件的時候,這時__name__的值就是咱們這個py文件的名字而不是__main__。

      這個功能還有一個用處:調試代碼的時候,在」if __name__ == '__main__'「中加入一些咱們的調試代碼,咱們可讓外部模塊調用的時候不執行咱們的調試代碼,可是若是咱們想排查問題的時候,直接執行該模塊文件,調試代碼可以正常運行!s

3   

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
##-------------cal.py
def  add(x,y):
 
     return  x + y
##-------------main.py
import  cal       #from module import cal
 
def  main():
 
     cal.add( 1 , 2 )
     
##--------------bin.py
from  module  import  main
 
main.main()
  注意
相關文章
相關標籤/搜索