日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

property、staticmethod、classmethod与__str__的用法

發布時間:2025/3/19 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 property、staticmethod、classmethod与__str__的用法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

import math class Circle:def __init__(self,radius): #圓的半徑radiusself.radius=radius@propertydef area(self):return math.pi * self.radius**2 #計算面積@propertydef perimeter(self):return 2*math.pi*self.radius #計算周長c=Circle(10) print(c.radius) print(c.area) #可以向訪問數據屬性一樣去訪問area,會觸發一個函數的執行,動態計算出一個值 print(c.perimeter) #同上 ''' 輸出結果: 314.1592653589793 62.83185307179586 '''

?

?

?python并沒有在語法上把它們三個內建到自己的class機制中,在C++里一般會將所有的所有的數據都設置為私有的,然后提供set和get方法(接口)去設置和獲取,在python中通過property方法可以實現
?

class Foo:def __init__(self,val):self.__NAME=val #將所有的數據屬性都隱藏起來@propertydef name(self):return self.__NAME #obj.name訪問的是self.__NAME(這也是真實值的存放位置)@name.setterdef name(self,value):if not isinstance(value,str): #在設定值之前進行類型檢查raise TypeError('%s must be str' %value)self.__NAME=value #通過類型檢查后,將值value存放到真實的位置self.__NAME@name.deleterdef name(self):raise TypeError('Can not delete')f=Foo('egon') print(f.name) # f.name=10 #拋出異常'TypeError: 10 must be str' del f.name #拋出異常'TypeError: Can not delete' class Foo:def __init__(self,val):self.__NAME=val #將所有的數據屬性都隱藏起來def getname(self):return self.__NAME #obj.name訪問的是self.__NAME(這也是真實值的存放位置)def setname(self,value):if not isinstance(value,str): #在設定值之前進行類型檢查raise TypeError('%s must be str' %value)self.__NAME=value #通過類型檢查后,將值value存放到真實的位置self.__NAMEdef delname(self):raise TypeError('Can not delete')name=property(getname,setname,delname) #不如裝飾器的方式清晰一種property的古老用法

?

class Foo:def spam(x,y,z): #類中的一個函數,千萬不要懵逼,self和x啥的沒有不同都是參數名print(x,y,z)spam=staticmethod(spam) #把spam函數做成靜態方法

?基于之前所學裝飾器的知識,@staticmethod 等同于spam=staticmethod(spam),于是
?

class Foo:@staticmethod #裝飾器def spam(x,y,z):print(x,y,z) print(type(Foo.spam)) #類型本質就是函數 Foo.spam(1,2,3) #調用函數應該有幾個參數就傳幾個參數f1=Foo() f1.spam(3,3,3) #實例也可以使用,但通常靜態方法都是給類用的,實例在使用時喪失了自動傳值的機制''' <class 'function'> 3 3 '''

應用場景:編寫類時需要采用很多不同的方式來創建實例,而我們只有一個__init__函數,此時靜態方法就派上用場了
?

class Date:def __init__(self,year,month,day):self.year=yearself.month=monthself.day=day@staticmethoddef now(): #用Date.now()的形式去產生實例,該實例用的是當前時間t=time.localtime() #獲取結構化的時間格式return Date(t.tm_year,t.tm_mon,t.tm_mday) #新建實例并且返回@staticmethoddef tomorrow():#用Date.tomorrow()的形式去產生實例,該實例用的是明天的時間t=time.localtime(time.time()+86400)return Date(t.tm_year,t.tm_mon,t.tm_mday)a=Date('1987',11,27) #自己定義時間 b=Date.now() #采用當前時間 c=Date.tomorrow() #采用明天的時間print(a.year,a.month,a.day) print(b.year,b.month,b.day) print(c.year,c.month,c.day)

類方法是給類用的,類在使用時會將類本身當做參數傳給類方法的第一個參數,python為我們內置了函數classmethod來把類中的函數定義成類方法
?

class A:x=1@classmethoddef test(cls):print(cls,cls.x)class B(A):x=2 B.test()''' 輸出結果: <class '__main__.B'> 2 '''

應用場景:
?

import time class Date:def __init__(self,year,month,day):self.year=yearself.month=monthself.day=day@staticmethoddef now():t=time.localtime()return Date(t.tm_year,t.tm_mon,t.tm_mday)class EuroDate(Date):def __str__(self):return 'year:%s month:%s day:%s' %(self.year,self.month,self.day)e=EuroDate.now() print(e) #我們的意圖是想觸發EuroDate.__str__,但是結果為 ''' 輸出結果: <__main__.Date object at 0x1013f9d68> '''

因為e就是用Date類產生的,所以根本不會觸發EuroDate.__str__,解決方法就是用classmethod
?

import time class Date:def __init__(self,year,month,day):self.year=yearself.month=monthself.day=day# @staticmethod# def now():# t=time.localtime()# return Date(t.tm_year,t.tm_mon,t.tm_mday)@classmethod #改成類方法def now(cls):t=time.localtime()return cls(t.tm_year,t.tm_mon,t.tm_mday) #哪個類來調用,即用哪個類cls來實例化class EuroDate(Date):def __str__(self):return 'year:%s month:%s day:%s' %(self.year,self.month,self.day)e=EuroDate.now() print(e) #我們的意圖是想觸發EuroDate.__str__,此時e就是由EuroDate產生的,所以會如我們所愿 ''' 輸出結果: year:2017 month:3 day:3 '''

?強調,注意注意注意:靜態方法和類方法雖然是給類準備的,但是如果實例去用,也是可以用的,只不過實例去調用的時候容易讓人混淆,不知道你要干啥

x=e.now() #通過實例e去調用類方法也一樣可以使用,靜態方法也一樣 print(x) ''' 輸出結果: year:2017 month:3 day:3 '''

#__str__定義在類內部,必須返回一個字符串類型, #什么時候會出發它的執行呢?打印由這個類產生的對象時,會觸發執行class People:def __init__(self,name,age):self.name=nameself.age=agedef __str__(self):return '<name:%s,age:%s>' %(self.name,self.age)p1=People('egon',18) print(p1) str(p1) #----->p1.__str__()

?

總結

以上是生活随笔為你收集整理的property、staticmethod、classmethod与__str__的用法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。