Python3導(dǎo)入自定義模塊的三種方法詳解
前話
最近跟著廖雪峰的教程學(xué)到 模塊 這一節(jié)。關(guān)于如何自定義一個(gè)模塊,如果大家不懂的話先來看看基本的介紹:
模塊
在計(jì)算機(jī)程序的開發(fā)過程中,隨著程序代碼越寫越多,在一個(gè)文件里代碼就會越來越長,越來越不容易維護(hù)。
為了編寫可維護(hù)的代碼,我們把很多函數(shù)分組,分別放到不同的文件里,這樣,每個(gè)文件包含的代碼就相對較少,很多編程語言都采用這種組織代碼的方式。在Python中,一個(gè).py文件就稱之為一個(gè)模塊(Module)。
使用模塊有什么好處?
最大的好處是大大提高了代碼的可維護(hù)性。其次,編寫代碼不必從零開始。當(dāng)一個(gè)模塊編寫完畢,就可以被其他地方引用。我們在編寫程序的時(shí)候,也經(jīng)常引用其他模塊,包括Python內(nèi)置的模塊和來自第三方的模塊。
使用模塊還可以避免函數(shù)名和變量名沖突。相同名字的函數(shù)和變量完全可以分別存在不同的模塊中,因此,我們自己在編寫模塊時(shí),不必考慮名字會與其他模塊沖突。但是也要注意,盡量不要與內(nèi)置函數(shù)名字沖突。點(diǎn)這里查看Python的所有內(nèi)置函數(shù)。
你也許還想到,如果不同的人編寫的模塊名相同怎么辦?為了避免模塊名沖突,Python又引入了按目錄來組織模塊的方法,稱為包(Package)。
舉個(gè)例子,一個(gè)abc.py的文件就是一個(gè)名字叫abc的模塊,一個(gè)xyz.py的文件就是一個(gè)名字叫xyz的模塊。
現(xiàn)在,假設(shè)我們的abc和xyz這兩個(gè)模塊名字與其他模塊沖突了,于是我們可以通過包來組織模塊,避免沖突。方法是選擇一個(gè)頂層包名,比如mycompany,按照如下目錄存放:
mycompany
├─ __init__.py
├─ abc.py
└─ xyz.py
引入了包以后,只要頂層的包名不與別人沖突,那所有模塊都不會與別人沖突?,F(xiàn)在,abc.py模塊的名字就變成了mycompany.abc,類似的,xyz.py的模塊名變成了mycompany.xyz。
請注意,每一個(gè)包目錄下面都會有一個(gè)__init__.py的文件,這個(gè)文件是必須存在的,否則,Python就把這個(gè)目錄當(dāng)成普通目錄,而不是一個(gè)包。__init__.py可以是空文件,也可以有Python代碼,因?yàn)開_init__.py本身就是一個(gè)模塊,而它的模塊名就是mycompany。
類似的,可以有多級目錄,組成多級層次的包結(jié)構(gòu)。比如如下的目錄結(jié)構(gòu):
mycompany
├─ web
│ ├─ __init__.py
│ ├─ utils.py
│ └─ www.py
├─ __init__.py
├─ abc.py
└─ xyz.py
文件www.py的模塊名就是mycompany.web.www,兩個(gè)文件utils.py的模塊名分別是mycompany.utils和mycompany.web.utils。
自己創(chuàng)建模塊時(shí)要注意命名,不能和Python自帶的模塊名稱沖突。例如,系統(tǒng)自帶了sys模塊,自己的模塊就不可命名為sys.py,否則將無法導(dǎo)入系統(tǒng)自帶的sys模塊。
mycompany.web也是一個(gè)模塊,請指出該模塊對應(yīng)的.py文件。
小結(jié)
模塊是一組Python代碼的集合,可以使用其他模塊,也可以被其他模塊使用。
創(chuàng)建自己的模塊時(shí),要注意:
- 模塊名要遵循Python變量命名規(guī)范,不要使用中文、特殊字符;
- 模塊名不要和系統(tǒng)模塊名沖突,最好先查看系統(tǒng)是否已存在該模塊,檢查方法是在Python交互環(huán)境執(zhí)行import abc,若成功則說明系統(tǒng)存在此模塊。
模塊是個(gè)好東西啊,大牛們開源共享許多模塊也加快了大家開發(fā)的速度,許多開源模塊可以在這里找到 ↓
因?yàn)閯側(cè)腴T所有有很多細(xì)節(jié)不懂,在網(wǎng)上搜尋資料的時(shí)候發(fā)現(xiàn)各位大神們的教程實(shí)在太過于精簡,讓我這個(gè)菜鳥很辛苦的才操作成功。
因此在這里記錄下來。
開始
第一種,直接 import
這里有個(gè)大前提,就是你的py執(zhí)行文件和模塊同屬于同個(gè)目錄(父級目錄),如下圖:

- main.py 和 pwcong模塊同在python目錄
- 執(zhí)行文件為main.py
- pwcong文件夾為一個(gè)模塊
我把pwcong模塊提供的函數(shù)寫在 __init__.py 里,里面只提供一個(gè) hi 函數(shù):
# pwcong 模塊的 __init__.py
# -*- coding: utf-8 -*-
def hi():
print("hi")
執(zhí)行文件main.py直接import模塊:
# main.py # -*- coding: utf-8 -*- import pwcong pwcong.hi()
接著我們運(yùn)行一下main.py可以看到命令行窗口輸出了一句 hi ,第一種方式完成。
使用模塊方式為:先導(dǎo)入-》接著輸入模塊.變量|函數(shù), 如上面例子的 pwcong.hi()
第二種,通過sys模塊導(dǎo)入自定義模塊的path
如果執(zhí)行文件和模塊不在同一目錄,這時(shí)候直接import是找不到自定義模塊的。如下圖:

- 執(zhí)行文件main.py在main目錄下
- pwcong模塊在python目錄下
sys模塊是python內(nèi)置的,因此我們導(dǎo)入自定義模塊的步驟如下:
- 先導(dǎo)入sys模塊
- 然后通過
sys.path.append(path)函數(shù)來導(dǎo)入自定義模塊所在的目錄 - 導(dǎo)入自定義模塊。
這時(shí)候 main.py 這樣寫:
# main.py # -*- coding: utf-8 -*- import sys sys.path.append(r"C:\Users\Pwcong\Desktop\python") import pwcong pwcong.hi()
最后執(zhí)行main.py文件,最終輸出 hi ,第二種方式完成。
第三種,通過pth文件找到自定義模塊
這個(gè)方法原理就是利用了系統(tǒng)變量,python會掃描path變量的路徑來導(dǎo)入模塊,可以在系統(tǒng)path里面添加。但是我還是推薦使用pth文件添加。
模塊和執(zhí)行文件目錄結(jié)構(gòu)跟上圖一樣:

- 執(zhí)行文件main.py在main目錄下
- pwcong模塊在python目錄下
我們創(chuàng)建一個(gè) module_pwcong.pth 文件,里面內(nèi)容就是 pwcong模塊所在的目錄:
C:\Users\Pwcong\Desktop\python
將該 module_pwcong.pth 文件放到這里:
python安裝目錄\Python35\Lib\site-packages
例如我的:

然后 main.py 導(dǎo)入并使用自定義模塊:
# -*- coding: utf-8 -*- import pwcong pwcong.hi()
最后執(zhí)行 main.py 文件,可以輸出 hi ,第三種方式完成。
結(jié)束
到這里三種導(dǎo)入自定義模塊的方式栗子就完成了,我寫的應(yīng)該很詳細(xì)了吧 :)
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
Python中itertools庫的四個(gè)函數(shù)介紹
這篇文章主要介紹了Python中itertools庫的四個(gè)函數(shù),主要討論itertools庫中的十分使用的幾個(gè)函數(shù),并重點(diǎn)介紹什么時(shí)候我們應(yīng)該考慮使用它們,需要的朋友可以參考一下2022-04-04
在python plt圖表中文字大小調(diào)節(jié)的方法
今天小編就為大家分享一篇在python plt圖表中文字大小調(diào)節(jié)的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07
Django 自定義權(quán)限管理系統(tǒng)詳解(通過中間件認(rèn)證)
這篇文章主要介紹了Django 自定義權(quán)限管理系統(tǒng)詳解(通過中間件認(rèn)證),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03
使用Python爬取最好大學(xué)網(wǎng)大學(xué)排名
這篇文章主要介紹了如何使用Python爬取最好大學(xué)網(wǎng)大學(xué)排名,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02
使用Python將word中的圖片進(jìn)行導(dǎo)出功能
這篇文章主要為大家詳細(xì)介紹了如何使用Python將word中的圖片進(jìn)行導(dǎo)出功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-01-01

