python模塊與包

来源:https://www.cnblogs.com/ghostwu/archive/2018/03/20/8612200.html
-Advertisement-
Play Games

一、.py文件可以看做一個模塊,模塊類似其他語言中封裝的類庫 模塊分類: 內置模塊 自定義模塊 第三方模塊(需要安裝才能使用) 我想要使用cal.py中定義的函數,可以這樣做 cal.py源代碼: import_test.py要使用add函數: 二,內置屬性__name__ cal.py 當執行ca ...


一、.py文件可以看做一個模塊,模塊類似其他語言中封裝的類庫

模塊分類:
  內置模塊
  自定義模塊
  第三方模塊(需要安裝才能使用)

我想要使用cal.py中定義的函數,可以這樣做

cal.py源代碼:

#!/usr/bin/python
#coding:utf-8

def add( a, b ):
    return a + b

import_test.py要使用add函數:

#!/usr/bin/python
#coding:utf-8

import cal

print cal.add( 10, 20 )

 

二,內置屬性__name__

cal.py

#!/usr/bin/python
#coding:utf-8

def add( a, b ):
    return a + b

print __name__
ghostwu@ghostwu:~/python$ python cal.py
__main__
ghostwu@ghostwu:~/python$ python import_test.py 
cal
30
ghostwu@ghostwu:~/python$ 

當執行cal.py本身時,__name__被解釋成__main__, 通過模塊引入方式執行時,別解釋成文件名,這個特性有什麼用?

#!/usr/bin/python
#coding:utf-8

def add( a, b ):
    return a + b

if __name__ == '__main__':
    print add( 100, 200 )
ghostwu@ghostwu:~/python$ python import_test.py 
30
ghostwu@ghostwu:~/python$ python cal.py
300

這就是__name__的一個小作用,當一個模塊(.py文件)被別的文件調用時,一般是想調用它裡面定義的函數或者方法,我們可以通過__name__讓外部模塊調用方式,不會執行到類似print add( 100, 200 )這樣的

具體業務代碼。只用到裡面的函數或者方法定義。

 

三、模塊載入順序:

當前目錄如果有同名的系統模塊,那麼當前目錄的模塊會被import,系統模塊會被忽略,如:

 1 ghostwu@ghostwu:~/python/module$ ls
 2 import_test.py  string.py
 3 ghostwu@ghostwu:~/python/module$ cat string.py 
 4 #!/usr/bin/python
 5 #coding:utf-8
 6 
 7 def add( a, b ):
 8     return a + b
 9 ghostwu@ghostwu:~/python/module$ cat import_test.py 
10 #!/usr/bin/python
11 #coding:utf-8
12 import string
13 str = 'ghostwu'
14 print string.capitalize( str )
15 
16 ghostwu@ghostwu:~/python/module$ python import_test.py 
17 Traceback (most recent call last):
18   File "import_test.py", line 8, in <module>
19     print string.capitalize( str )
20 AttributeError: 'module' object has no attribute 'capitalize'
21 ghostwu@ghostwu:~/python/module$ ls -a
22 .  ..  import_test.py  string.py  string.pyc

在當前目錄下,定義了一個同名的string模塊( 指的是與系統的string模塊同名 ),由於執行的時候,當前目錄的模塊被import了,所以識別不了系統string模塊的方法capttalize.

只要刪除目錄下的string.py string.pyc,就能正常import系統的模塊 

1 ghostwu@ghostwu:~/python/module$ ls -a
2 .  ..  import_test.py  string.py  string.pyc
3 ghostwu@ghostwu:~/python/module$ rm string.py string.pyc
4 ghostwu@ghostwu:~/python/module$ ls -a
5 .  ..  import_test.py
6 ghostwu@ghostwu:~/python/module$ python import_test.py 
7 Ghostwu

 

四,當一個目錄下有__init__.py文件,就可以當做一個包來用

 1 ghostwu@ghostwu:~/python/package_test$ pwd
 2 /home/ghostwu/python/package_test
 3 ghostwu@ghostwu:~/python/package_test$ ls -a
 4 .  ..  calc.py  calc.pyc  fab.py  fab.pyc  __init__.py  __init__.pyc
 5 ghostwu@ghostwu:~/python/package_test$ cat calc.py
 6 #!/usr/bin/python
 7 #coding:utf-8
 8 
 9 def add( a, b ):
10     return a + b
11 
12 def sbb( a, b ):
13     return a - b
14 
15 def mul( a, b ):
16     return a * b
17 
18 def div( a, b ):
19     return a / b
20 
21 oper = { '+' : add, '-' : sbb, '*' : mul, '/' : div }
22 
23 def mySwitch( x, o, y ):
24     return oper.get( o )( x, y )
25 
26 ghostwu@ghostwu:~/python/package_test$ cat fab.py
27 #!/usr/bin/python
28 #coding:utf-8
29 
30 def fab( n ):
31     if n == 0:
32         return 1
33     else:
34         return n * fab( n - 1)

在test.py中,引用包中的模塊

 1 ghostwu@ghostwu:~/python/package_test$ cd ..
 2 ghostwu@ghostwu:~/python$ ls -a
 3 .  ..  module  package_test  test.py  tmp
 4 ghostwu@ghostwu:~/python$ cat test.py 
 5 #!/usr/bin/python
 6 #coding:utf-8
 7 
 8 import package_test.calc
 9 import package_test.fab
10 
11 print package_test.calc.add( 10, 20 )
12 print package_test.fab.fab( 6 )
13 ghostwu@ghostwu:~/python$ python test.py 
14 30
15 720
16 ghostwu@ghostwu:~/python$ 

導入模塊的另外兩種方式: 別名與直接導入方法

 1 ghostwu@ghostwu:~/python/package_test$ ls
 2 calc.py  calc.pyc  fab.py  fab.pyc  __init__.py  __init__.pyc
 3 ghostwu@ghostwu:~/python/package_test$ python
 4 Python 2.7.12 (default, Dec  4 2017, 14:50:18) 
 5 [GCC 5.4.0 20160609] on linux2
 6 Type "help", "copyright", "credits" or "license" for more information.
 7 >>> import calc
 8 >>> calc.add( 10, 20 )
 9 30
10 >>> import calc as c
11 >>> c.add( 100, 200 )
12 300
13 >>> from calc import add
14 >>> add( 1, 2 )
15 3

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 為什麼這樣說呢,我幾個月前就開始學python,但是一直都沒有進步,還就只是會一些其它語言的共性的問題,也就是新學習的約等於0. 後來一直找一些適合自己的教材,通過同學找到了一個學長的教程。 開始了新的python旅程 最近打字有點懶了五筆都有點生疏了 還是看手抄版的筆記吧 給自己學習的動力從新的一 ...
  • 註:這裡只描述使用方法,具體類的概念長篇大論就不要為難我這個懶人了。 總之一句話編程語言只是一個工具,會用就行,好用就行。打破砂鍋問到底,我覺得有必要研究一下C,彙編,電子鏈路等。 ...
  • 一、SpringData入門 在上次學SpringBoot的時候,那時候的教程就已經涉及到了一點SpringData JPA的知識了。當時還是第一次見,覺得也沒什麼大不了,就是封裝了Hibernate的API而已。 然後在慕課網上又看到了SpringData的教程了。於是就進去學習了一番。 教程地址 ...
  • 一、實體基本映射 二、實體表間映射 1、一對一實體映射:人與地址 2、一對多實體映射:員工表與部門表 3、多對多實體映射:老師與學生 ...
  • 1,首字母大寫 2,replace,替換 查幫助 如果是面向過程的函數用法,直接help( 函數名 ),如help( abs ) 用法說明: replace(...) S.replace(old, new[, count]) -> string Return a copy of string S w ...
  • Description 有n位同學,每位同學都參加了全部的m門課程的期末考試,都在焦急的等待成績的公佈。第i位同學希望在第ti天 或之前得知所.有.課程的成績。如果在第ti天,有至少一門課程的成績沒有公佈,他就會等待最後公佈成績的課程 公佈成績,每等待一天就會產生C不愉快度。對於第i門課程,按照原本 ...
  • 基本概念 問題空間:問題空間是問題解決者對一個問題所達到的全部認識狀態,它是由問題解決者利用問題所包含的信息和已貯存的信息主動的地構成的。 初始狀態:一開始時的不完全的信息或令人不滿意的狀況; 目標狀態:你希望獲得的信息或狀態; 操作:為了從初始狀態邁向目標狀態,你可能採取的步驟。 對象:對象(ob ...
  • 操作系統 : CentOS7.3.1611_x64 gcc版本 :4.8.5 Python 版本 : 2.7.5 思路如下 : 1、將浮點數a通過記憶體拷貝,賦值給相同位元組的整型數據b; 2、將b轉換為網路位元組序變數c併發送到服務端; 3、服務端接收c並將c轉換為主機位元組序變數d; 4、將整型數據d通 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...