掃碼關注『Python3X』
一個純粹的Python類公眾號
昨天推送的Python Every Day 1、因為寫完沒有仔細檢查有點問題。所以刪了。給大家說聲抱歉。
最近創建了一個GitHub項目,主要會分享一些Python方面面試題和練習題,
訪問地址:https://github.com/python3xxx/Python-Every-Day
(點擊閱讀原文,直達)
Python Every Day, 第 2 天
python中的定義類方法有三種形式
普通方法
類方法(@classmethod)
靜態方法(@staticmethod)
1、普通方法的使用
class A():
def __init__(self, name, age):
self.name = name
self.age = age
def get_name(self):
print('my name is', self.name)
def get_age(self):
print(f'i am {self.age} years old')
class B():
def get_name(self, name):
print('my name is', name)
def get_age(self, age):
print(f'i am {age} years old')
if __name__ == '__main__':
a = A('tom',19)
a.get_name()
a.get_age()
b = B()
b.get_name('tom')
b.get_age(19)
如上所示,創建普通的方法的方式有兩種(class A() & class B()).
class A() 中, __init__()是一個特殊的方法,相當於對A進行初始化,__init__ 中的self是對象A本身,name和age是它們的形參。
每次調用方法之前需要對類進行實例化, 例如 a = A('tom', 19)
2、類方法(@classmethod)
普通方法中,每次調用類中的方法,都需要先將類進行實例化,相對比較麻煩。如果類中的函數前面加上@classmethod 或者 @staticmethod,則就不用再進行實例化了。直接 類名.函數名 進行調用
@classmethod不需要self來表示自身了,而是用了cls來代替。
示例如下:
class C():
@classmethod
def get_name(cls, name):
print(cls)
print('my name is %s' % name)
@classmethod
def get_age(cls, age):
print(f'i am %s years old' % age)
if __name__ == '__main__':
C.get_name('tom')
C.get_age(19)
3、靜態方法(@staticmethod)
靜態方法也是通過 類名.函數名 的方式進行調用,與類方法類似,不同的是,靜態方法不需要表示自身對象的self或者cls作為參數,跟直接使用函數是一樣的。
class D():
@staticmethod
def get_name(name):
print('my name is %s' % name)
@staticmethod
def get_age(age):
print(f'i am %s years old' % age)
if __name__ == '__main__':
D.get_name('tom')
D.get_age(19)
總結
@staticmethod 與 @classmethod在Python中稱為 裝飾器,用來修飾函數,相當於添加一個額外的功能,比如不再像普通函數那樣進行實例化。通過使用裝飾器可以讓代碼更加整潔,易讀。用了修飾器之後,也可以進行實例化之後再調用,但是就顯得多此一舉了。