[Python基礎]裝飾器staticmethod 定義靜態方法

更新於 發佈於 閱讀時間約 7 分鐘

先前學到自定函式的使用方法,那如果在一個很龐大的程式架構中發散了一推自定函式,有沒有辦法可以整理一下,讓程式結構整齊又簡潔呢?

可以使用裝飾器staticmethod 定義靜態方法,讓相關聯的自定函式變成用類別中的靜態方法,全部整理到一個類別去,想像成是一個工具箱的概念,工具箱就是類別,靜態方法好像裡面的工具一樣,從哪個工具箱拿出這個工具,就像從哪個類別拿出靜態方法來用一樣,先有這初步的概念,讓我們從範例中更深刻理解吧。


靜態方法的特點:

  1. 靜態方法與類別的實例無關,因此它不需要訪問實例變數。
  2. 靜態方法可以訪問類別本身的屬性或方法。
  3. 只有單一實現的時候。不希望子類別覆寫該函數,確保該函數不被覆寫就可用@staticmethod

靜態方法的應用場景:

  • 當某個方法與類別相關,但不需要訪問實例變數時,可以使用靜態方法。
  • 靜態方法通常與類別相關的邏輯,但不需要實例化類別的情況下使用。

語法

staticmethod靜態方法定義方式如下:

class MyClass:
@staticmethod
def my_static_method(arg1, arg2, ...):
# 靜態方法的實現
# 這裡不能訪問實例變數,只能訪問類別變數或其他靜態成員
pass

程式範例

定義函式與靜態方法差異

在這個例子中,addmultiply 方法是靜態方法,可以直接使用類別名稱呼叫,不需要實例化 MathUtils

靜態方法可以防止全局命名衝突。這種方式還允許在 MathUtils 類別中添加更多相關的靜態方法,以實現更多相關的功能,例如創建一個自己專屬的數學工具庫。

在此範例中result2 = MathUtils.multiply(4, 6)MathUtils就是我們的工具箱,拿出了multiply這個工具來作使用。

# 使用函式定義實現相關功能

def add(x, y):
return x + y

def multiply(x, y):
return x * y

# 使用模塊層級的函式
result1 = add(5, 3)
result2 = multiply(4, 6)

print(result1) # 輸出: 8
print(result2) # 輸出: 24


# 使用靜態方法實現相同的功能
class MathUtils:
@staticmethod
def add(x, y):
return x + y

@staticmethod
def multiply(x, y):
return x * y

# 使用靜態方法,不需要實例化類別
result1 = MathUtils.add(5, 3)
result2 = MathUtils.multiply(4, 6)

print(result1) # 輸出: 8
print(result2) # 輸出: 24

靜態方法與類別方法的差異

靜態方法通常用於與類別相關但與實例狀態無關的操作,

類別方法通常用於需要訪問修改類別屬性的操作。


靜態方法 square_area使用@staticmethod裝飾器修飾。

通過類別名稱 MathOperations 調用,不需要實例化。

該方法接受一個參數 side_length,計算正方形的面積並返回結果。


類別方法 circle_area使用 @classmethod 裝飾器修飾。

通過類別名稱 MathOperations 來調用,不需要實例化。

該方法接受兩個參數cls 代表類別本身radius 是計算圓形面積所需的半徑。

該方法使用了類別屬性 pi,並計算圓形的面積。

class MathOperations:
# 類別屬性
pi = 3.14

# 靜態方法:計算正方形面積
@staticmethod
def square_area(side_length):
return side_length ** 2

# 類別方法:計算圓形面積
@classmethod
def circle_area(cls, radius):
return cls.pi * radius ** 2

# 使用靜態方法,無需實例化
square_result = MathOperations.square_area(5)

# 使用類別方法,需使用類別名稱
circle_area_result = MathOperations.circle_area(2)

print(square_result) # 輸出: 25
print(circle_area_result) # 輸出: 12.56

不同的類別中使用相同的靜態方法

當靜態方法提供一些通用的、與類別相關的操作時,其他類別也可以輕鬆調用這些方法。

我們創建了兩個產品,分別是一台筆記型電腦和一部智能手機。

通過 display_price_in_local_currency 方法,我們可以將這兩個產品的價格以本地貨幣的形式顯示。

class CurrencyConverter:
exchange_rate = 1.1 # 貨幣兌換率(假設 1 單位的本地貨幣等於 1.1 單位的外幣)

@staticmethod
def convert_to_foreign_currency(amount):
return amount * CurrencyConverter.exchange_rate

class Product:
def __init__(self, name, price):
self.name = name
self.price = price

def display_price_in_local_currency(self):
local_price = CurrencyConverter.convert_to_foreign_currency(self.price)
print(f"{self.name} 在當地價格是: {local_price}")

# 使用範例
product1 = Product("Laptop", 1000)
product2 = Product("Smartphone", 500)

product1.display_price_in_local_currency() # 輸出 Laptop 在當地價格是: 1100.0
product2.display_price_in_local_currency() # 輸出 Smartphone 在當地價格是: 550.0

這個範例中,CurrencyConverter 提供了一個通用的靜態方法,可以在整個應用程序中重複使用,而不需要實例化類別。Product 類別則使用了這個通用的靜態方法,以實現價格的轉換顯示。這種結構使得代碼更加模組化和可維護。


總結

靜態方法優點:

  • 模組化和可重複使用。
  • 它的行為只取決於傳入的參數。這使得靜態方法更加獨立和可預測。
  • 可提高程式碼組織結構: 靜態方法通常用於執行與特定類別相關的通用操作
  • 模組化的設計有助於提高程式碼的可讀性,同時更容易進行維護和測試。
  • 節省資源使用: 由於靜態方法無需實例化類別,這在執行某些通用操作時可能具有性能優勢。



在整理學習時,也在想裝飾器staticmethod 定義靜態方法還有沒有更好的用處,是我沒想到的

如果您知道更能發揮它的效用,在留言分享一下,謝謝





avatar-img
134會員
222內容數
本業是影像辨識軟體開發,閒暇時間進修AI相關內容,將學習到的內容寫成文章分享。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
螃蟹_crab的沙龍 的其他內容
在使用類別創建實例時,輸入的屬性的都要定義好資料型態,例如dog_1 = Dog("Buddy", 3),有沒有輸入一段字串讓他自己判斷的方法阿? 有的就是使用classmethod: classmethod 是一種裝飾器,它用於定義類別方法。類別方法與實例方法不同,它們被綁定到類別而不是實例。
當你想讓原本函式新增其他功能,又不想更動原本函式時,Python提供了一種強大而靈活的工具,那就是裝飾器。 但對於新手來說這個裝飾器,非常抽象難以理解,讓我們繼續往下看,慢慢的抽絲剝繭吧。 在 Python 中,使用「@」當做裝飾器使用的語法糖符號
在人與人溝通之間,最怕雞同鴨講,彼此不對頻的狀況常會造成誤會。在程式語言中也會出現類似的情況,所以就有一些約定來彼此約束。 PEP 8 是 Python 社群廣泛遵循的一種風格指南,用於提高 Python 程式碼的可讀性和一致性。一開始是 Python 之父 Guido van Rossum 自己
在Python函式中,可以使用None來指定動態的預設引數,使用更靈活,Docstrings同時能夠提供清晰的文檔。本篇文章說明利用這種方式來讓函式更彈性,輸入不同型態的關鍵字引數,並在事件紀錄時間的Log訊息的範例中詮釋,可自行輸入時間或者預設導入系統的時間,在跟其他程式交握時,可以更靈活的應用。
本文介紹了Python中函式引數的*args和**kwargs用法,通過*args處理可變數量的位置引數,通過**kwargs處理可變數量的關鍵字引數。不僅介紹了相應的語法和程式範例,還解釋了它們的順序問題和建議的慣例用法。
本文介紹了串列運算式的應用,以及與Lambda匿名函式方法的比較,並提供了程式範例。串列運算式提供了一種簡潔的語法,用於創建、轉換和過濾列表。lambda函式用於創建匿名函式,通常用於簡單的操作。建議在比較複雜的情況下使用一般for迴圈加if來表示。
在使用類別創建實例時,輸入的屬性的都要定義好資料型態,例如dog_1 = Dog("Buddy", 3),有沒有輸入一段字串讓他自己判斷的方法阿? 有的就是使用classmethod: classmethod 是一種裝飾器,它用於定義類別方法。類別方法與實例方法不同,它們被綁定到類別而不是實例。
當你想讓原本函式新增其他功能,又不想更動原本函式時,Python提供了一種強大而靈活的工具,那就是裝飾器。 但對於新手來說這個裝飾器,非常抽象難以理解,讓我們繼續往下看,慢慢的抽絲剝繭吧。 在 Python 中,使用「@」當做裝飾器使用的語法糖符號
在人與人溝通之間,最怕雞同鴨講,彼此不對頻的狀況常會造成誤會。在程式語言中也會出現類似的情況,所以就有一些約定來彼此約束。 PEP 8 是 Python 社群廣泛遵循的一種風格指南,用於提高 Python 程式碼的可讀性和一致性。一開始是 Python 之父 Guido van Rossum 自己
在Python函式中,可以使用None來指定動態的預設引數,使用更靈活,Docstrings同時能夠提供清晰的文檔。本篇文章說明利用這種方式來讓函式更彈性,輸入不同型態的關鍵字引數,並在事件紀錄時間的Log訊息的範例中詮釋,可自行輸入時間或者預設導入系統的時間,在跟其他程式交握時,可以更靈活的應用。
本文介紹了Python中函式引數的*args和**kwargs用法,通過*args處理可變數量的位置引數,通過**kwargs處理可變數量的關鍵字引數。不僅介紹了相應的語法和程式範例,還解釋了它們的順序問題和建議的慣例用法。
本文介紹了串列運算式的應用,以及與Lambda匿名函式方法的比較,並提供了程式範例。串列運算式提供了一種簡潔的語法,用於創建、轉換和過濾列表。lambda函式用於創建匿名函式,通常用於簡單的操作。建議在比較複雜的情況下使用一般for迴圈加if來表示。
你可能也想看
Google News 追蹤
提問的內容越是清晰,強者、聰明人越能在短時間內做判斷、給出精準的建議,他們會對你產生「好印象」,認定你是「積極」的人,有機會、好人脈會不自覺地想引薦給你
Thumbnail
這篇內容,將會講解什麼是方法,以及與方法相關的知識。包括定義Method、Method Variable 方法變數、跨區使用Method、使用函式時要注意括號。
Thumbnail
這篇內容,將會講解什麼是函式,以及與函式相關的知識。包括函式的簡介、Runtime Function、自訂函式、Script Function 腳本函式、Method 方法。
Thumbnail
打開 jupyter notebook 寫一段 python 程式,可以完成五花八門的工作,這是玩程式最簡便的方式,其中可以獲得很多快樂,在現今這種資訊發達的時代,幾乎沒有門檻,只要願意,人人可享用。 下一步,希望程式可以隨時待命聽我吩咐,不想每次都要開電腦,啟動開發環境,只為完成一個重複性高
Thumbnail
因為最近想嘗試編碼風格,於是就選了一套比較"不嚴格"的輔助工具來摸索。 編輯器 VS CODE 框架 VUE3 打包工具 VITE 編碼風格 Standard 環境 version { "nodejs":"v18.18.0", "npm":"9.8.1" }
NumPy(Numeric Python)是Python中用於科學計算的核心庫之一。它提供了高性能的多維陣列對象(即ndarray)以及用於處理這些陣列的各種函數和工具。 在NumPy中,有幾個常用的指令可以用來創建陣列
Thumbnail
讀取ini配置文件時如果某個參數不存在,它就會報錯,要怎麼避免呢? 可以使用fallback 參數來指定預設值。 這樣即使配置文件中缺少一些參數,我們的程序也能正常運行並使用預設值。 讓我們來假設一個案例做說明: 先故意將先前範例的port的資料刪掉。
Thumbnail
INI 檔案是一種配置檔案格式,常用於保存設定資料和組態資訊。 它使用簡單的鍵值對結構來組織資料,通常用於程式、應用程式或操作系統中的配置和初始化設定。 INI 檔案每個鍵值對包含一個名稱(鍵)和對應的值。 基本的檔案格式如下: [Section1] Key1 = Value1 Key2 =
Thumbnail
前幾篇討論到各種裝飾器的用法,本文將介紹另外一種裝飾器,可以將方法轉換成屬性來使用。 property也可以動態的取出物件的值,隨著時間或其他運算改變所產生的值,讓我們繼續往下看更多介紹吧。
Thumbnail
先前我們談論到靜態方法就像是定義工具箱一樣,那麼抽象方法就像是共用表格的概念,例如註冊帳號時會填寫的一些基本資料,就有包含制式的表格,裡面有需填寫的欄位,例如姓名,性別等。
提問的內容越是清晰,強者、聰明人越能在短時間內做判斷、給出精準的建議,他們會對你產生「好印象」,認定你是「積極」的人,有機會、好人脈會不自覺地想引薦給你
Thumbnail
這篇內容,將會講解什麼是方法,以及與方法相關的知識。包括定義Method、Method Variable 方法變數、跨區使用Method、使用函式時要注意括號。
Thumbnail
這篇內容,將會講解什麼是函式,以及與函式相關的知識。包括函式的簡介、Runtime Function、自訂函式、Script Function 腳本函式、Method 方法。
Thumbnail
打開 jupyter notebook 寫一段 python 程式,可以完成五花八門的工作,這是玩程式最簡便的方式,其中可以獲得很多快樂,在現今這種資訊發達的時代,幾乎沒有門檻,只要願意,人人可享用。 下一步,希望程式可以隨時待命聽我吩咐,不想每次都要開電腦,啟動開發環境,只為完成一個重複性高
Thumbnail
因為最近想嘗試編碼風格,於是就選了一套比較"不嚴格"的輔助工具來摸索。 編輯器 VS CODE 框架 VUE3 打包工具 VITE 編碼風格 Standard 環境 version { "nodejs":"v18.18.0", "npm":"9.8.1" }
NumPy(Numeric Python)是Python中用於科學計算的核心庫之一。它提供了高性能的多維陣列對象(即ndarray)以及用於處理這些陣列的各種函數和工具。 在NumPy中,有幾個常用的指令可以用來創建陣列
Thumbnail
讀取ini配置文件時如果某個參數不存在,它就會報錯,要怎麼避免呢? 可以使用fallback 參數來指定預設值。 這樣即使配置文件中缺少一些參數,我們的程序也能正常運行並使用預設值。 讓我們來假設一個案例做說明: 先故意將先前範例的port的資料刪掉。
Thumbnail
INI 檔案是一種配置檔案格式,常用於保存設定資料和組態資訊。 它使用簡單的鍵值對結構來組織資料,通常用於程式、應用程式或操作系統中的配置和初始化設定。 INI 檔案每個鍵值對包含一個名稱(鍵)和對應的值。 基本的檔案格式如下: [Section1] Key1 = Value1 Key2 =
Thumbnail
前幾篇討論到各種裝飾器的用法,本文將介紹另外一種裝飾器,可以將方法轉換成屬性來使用。 property也可以動態的取出物件的值,隨著時間或其他運算改變所產生的值,讓我們繼續往下看更多介紹吧。
Thumbnail
先前我們談論到靜態方法就像是定義工具箱一樣,那麼抽象方法就像是共用表格的概念,例如註冊帳號時會填寫的一些基本資料,就有包含制式的表格,裡面有需填寫的欄位,例如姓名,性別等。