成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一日一技:什么情況使用靜態方法和類方法?

開發 前端
最近有同學在知識星球上問,什么情況下使用靜態方法,什么情況下使用類方法。今天我們就來捋一下這兩個方法的應用場景。

[[427633]]

最近有同學在知識星球上問,什么情況下使用靜態方法,什么情況下使用類方法。今天我們就來捋一下這兩個方法的應用場景。

首先,我們來定義一個普通的類,里面都是普通的方法,普通方法又叫實例方法。

  1. class People: 
  2.     def __init__(self, name, age): 
  3.         self.name = name 
  4.         self.age = age 
  5.  
  6.     def introduce_myself(self): 
  7.         print(f'大家好,我叫: {self.name}'
  8.  
  9.     def add_two_string_num(self, a, b): 
  10.         a_int = int(a) 
  11.         b_int = int(b) 
  12.         return a_int + b_int 
  13.  
  14.     def calc_age_after_n_year(self, n): 
  15.         age = self.add_two_string_num(self.age, n) 
  16.         print(f'{n}年以后,我{age}歲'

這個類運行起來的效果如下圖所示:

大家注意在這個類里面的方法add_two_string_num,它接受兩個參數,并將他們轉換為int類型,然后相加并返回結果。這個過程非常簡單,但是,它跟People這個類有什么直接關系嗎?

其實這個方法跟這個類沒有什么直接關系,我們甚至把它改成函數都可以:

  1. def add_two_string_num(a, b): 
  2.     a_int = int(a) 
  3.     b_int = int(b) 
  4.     return a_int + b_int 
  5.  
  6. class People: 
  7.     def __init__(self, name, age): 
  8.         self.name = name 
  9.         self.age = age 
  10.  
  11.     def introduce_myself(self): 
  12.         print(f'大家好,我叫: {self.name}'
  13.  
  14.     def calc_age_after_n_year(self, n): 
  15.         age = add_two_string_num(self.age, n) 
  16.         print(f'{n}年以后,我{age}歲'
  17.  
  18.          
  19. kingname = People('kingname', 20) 
  20. kingname.introduce_myself() 
  21. kingname.calc_age_after_n_year(10) 

運行結果跟之前完全一樣:

我們可以說,add_two_string_num函數就是一個工具函數。工具函數接收參數,輸出結果,完全不關心誰在調用他,也不關心在哪里調用他。

但現在有一個比較尷尬的事情,這個函數,只有 People在調用,其它地方都沒有調用。單獨把它放到其它地方又顯得多余,弄成實例方法又浪費了self參數,這個時候,我們就可以用靜態方法:

  1. class People: 
  2.     def __init__(self, name, age): 
  3.         self.name = name 
  4.         self.age = age 
  5.  
  6.     def introduce_myself(self): 
  7.         print(f'大家好,我叫: {self.name}'
  8.  
  9.     @staticmethod 
  10.     def add_two_string_num(a, b): 
  11.         a_int = int(a) 
  12.         b_int = int(b) 
  13.         return a_int + b_int 
  14.  
  15.     def calc_age_after_n_year(self, n): 
  16.         age = People.add_two_string_num(self.age, n) 
  17.         print(f'{n}年以后,我{age}歲'
  18.  
  19.  
  20. kingname = People('kingname', 20) 
  21. kingname.introduce_myself() 
  22. kingname.calc_age_after_n_year(10) 

一句話總結:靜態方法就是某個類專用的工具函數。

說完了靜態方法,我們再說說類方法。什么情況下應該使用類方法呢?回答這個問題前,我先反問你一個問題,怎么把People類初始化成一個實例?

你說這還不簡單嗎,一行代碼就行了啊:

  1. xxx = People('xxx', 10) 

注意,這里你在初始化這個類的時候,你是一個一個參數傳入進去的。如果你用過順豐寄送快遞,你就會發現,填寫收件人的時候,有兩種方式,一種方式就像上面這樣,一個一個參數填進去。另一種方式,它給你一個輸入框,你把一段包含姓名,地址,手機號的文字粘貼進去,它自動解析。

那么,如果我現在給你一個字符串:我的名字:青南,我的年齡:20,把它提取出來。你怎么基于這個字符串生成People類的實例?

這個時候,你可能會這樣寫:

  1. import re 
  2. content = '我的名字:青南,我的年齡:20,把它提取出來' 
  3. name = re.search('名字:(.*?),', content).group(1) 
  4. age = re.search('年齡:(\d+)', content).group(1) 
  5. kingname = People(name, age) 

這樣做確實可以,但我能不能讓People這個類自動識別呢?其實是可以的,有兩種方法,一種方法是在__init__里面多加幾個參數,然后在初始化的時候,從這幾個參數里面解析,這個方法大家都知道,我就不多講了。我們來講講第二個方法,就是使用類方法。

我們只需要再定義一個類方法:

  1. import re 
  2.  
  3.  
  4. class People: 
  5.     def __init__(self, name, age): 
  6.         self.name = name 
  7.         self.age = age 
  8.  
  9.     def introduce_myself(self): 
  10.         print(f'大家好,我叫: {self.name}'
  11.  
  12.     @staticmethod 
  13.     def add_two_string_num(a, b): 
  14.         a_int = int(a) 
  15.         b_int = int(b) 
  16.         return a_int + b_int 
  17.  
  18.     @classmethod 
  19.     def from_chinese_string(cls, sentence): 
  20.         name = re.search('名字:(.*?),', content).group(1) 
  21.         age = re.search('年齡:(\d+)', content).group(1) 
  22.         return cls(name, age) 
  23.  
  24.  
  25.     def calc_age_after_n_year(self, n): 
  26.         age = People.add_two_string_num(self.age, n) 
  27.         print(f'{n}年以后,我{age}歲'
  28.  
  29.          
  30. content = '我的名字:青南,我的年齡:20,把它提取出來' 
  31. kingname = People.from_chinese_string(content) 
  32. kingname.introduce_myself() 
  33. kingname.calc_age_after_n_year(10) 

運行效果如下圖所示:

類方法使用裝飾器@classmethod來裝飾,并且它的第一個參數是隱式參數cls。這個參數其實就是People這個類本身。這個隱式參數在我們調用類方法的時候,是不需要傳入的。在這個類方法里面,相當于使用People初始化了一個實例,然后把這個實例返回了出去。

這樣做有什么好處呢?好處就在于我們完全不需要修改__init__,那么,也就不需要修改代碼里面其它調用了People類的地方。例如現在我又想增加從英文句子里面提取名字和年齡的功能,那么只需要再添加一個類方法就可以了:

  1. import re 
  2.  
  3.  
  4. class People: 
  5.     def __init__(self, name, age): 
  6.         self.name = name 
  7.         self.age = age 
  8.  
  9.     def introduce_myself(self): 
  10.         print(f'大家好,我叫: {self.name}'
  11.  
  12.     @staticmethod 
  13.     def add_two_string_num(a, b): 
  14.         a_int = int(a) 
  15.         b_int = int(b) 
  16.         return a_int + b_int 
  17.  
  18.     @classmethod 
  19.     def from_chinese_string(cls, sentence): 
  20.         name = re.search('名字:(.*?),', content).group(1) 
  21.         age = re.search('年齡:(\d+)', content).group(1) 
  22.         return cls(name, age) 
  23.  
  24.     @classmethod 
  25.     def from_english_string(cls, sentence): 
  26.         name = re.search('name: (.*?),', content).group(1) 
  27.         age = re.search('age: (\d+)', content).group(1) 
  28.         return cls(name, age) 
  29.  
  30.  
  31.     def calc_age_after_n_year(self, n): 
  32.         age = People.add_two_string_num(self.age, n) 
  33.         print(f'{n}年以后,我{age}歲'
  34.  
  35.          
  36. content = 'my name: kinganme, my age: 15 please extract them' 
  37. kingname = People.from_english_string(content) 
  38. kingname.introduce_myself() 
  39. kingname.calc_age_after_n_year(10) 

運行效果如下圖所示:

一句話總結:當你想使用工廠模式,根據不同的參數生成同一個類的不同對象的時候,就可以使用類方法。

其實如果大家使用過Python自帶的datetime模塊,你就會發現類方法無處不在:

  1. import datetime 
  2.  
  3. now = datetime.datetime.now() 
  4. dt = datetime.datetime.fromtimestamp(1633691412) 
  5. dt2 = datetime.datetime.fromisoformat('2021-10-08 19:10:05'

 這段代碼里面的.now()、.fromtimestamp()和 .fromisoformat(),都是類方法。他們最終返回的都是datetime.datetime對象,區別在于他們是根據不同類型的輸入參數生成的。

本文轉載自微信公眾號「未聞Code」,可以通過以下二維碼關注。轉載本文請聯系未聞Code公眾號。

 

責任編輯:武曉燕 來源: 未聞Code
相關推薦

2024-07-19 18:23:17

2024-05-24 09:07:06

JSONprint字符串

2021-10-11 20:02:49

Python父類方法

2021-10-15 21:08:31

PandasExcel對象

2021-04-27 22:15:02

Selenium瀏覽器爬蟲

2021-11-12 05:00:43

裝飾器代碼功能

2024-08-27 22:08:13

2024-10-16 21:47:15

2025-05-28 03:15:00

Scrapy數據sleep

2021-04-12 21:19:01

PythonMakefile項目

2024-12-27 00:44:44

MarkdownPrompt大模型

2021-06-01 21:24:44

多線程代碼搜索

2021-02-27 10:49:13

可視化分析資源

2022-06-28 09:31:44

LinuxmacOS系統

2023-10-28 12:14:35

爬蟲JavaScriptObject

2021-09-13 20:38:47

Python鏈式調用

2024-11-13 09:18:09

2021-04-05 14:47:55

Python多線程事件監控

2021-03-12 21:19:15

Python鏈式調用

2022-03-12 20:38:14

網頁Python測試
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久久免费精品 | 欧美精品一区二区免费 | 久久久久亚洲精品中文字幕 | 欧美精品成人一区二区三区四区 | 免费a级毛片在线播放 | 午夜免费网 | 国产精品欧美一区二区三区 | 一级爱爱片 | 亚洲福利精品 | 精品一区二区在线观看 | 一区二区免费在线 | 精品国产欧美一区二区三区不卡 | 免费久久精品 | 美女黄色在线观看 | 精品福利视频一区二区三区 | 2020亚洲天堂 | 亚洲视频在线看 | 国产亚洲精品久久久久久牛牛 | 精品国产乱码久久久久久蜜柚 | 国产在线视频网 | 国产视频中文字幕在线观看 | 小早川怜子xxxxaⅴ在线 | 久久久久久久国产 | 综合伊人 | 国产综合精品一区二区三区 | v亚洲| 欧美天堂在线 | 国产在线视频一区二区董小宛性色 | 欧美中文在线 | 亚洲精品电影在线观看 | 青青久在线视频 | 91亚洲国产成人精品一区二三 | 亚洲精品国产一区 | 精品熟人一区二区三区四区 | 视频在线一区二区 | 中文字幕精品一区二区三区精品 | 91精品国产综合久久香蕉麻豆 | 久久精品 | 国产精品毛片无码 | 精品国产一区二区三区久久久蜜月 | 久久久久久久久久久91 |