標籤:設定 setattr rgs prompt tab lap int 物件導向 img
類和執行個體:
定義 class 類名(父類名): 其中object是所有類的祖先類
__int__方法(兩個底線)表示把屬性綁定到類上,如下把name、score等屬性綁上去
注意類中所有方法的第一個參數都是self表示對象本身,調用的時候不需要傳遞這個參數
class Student(object): def __init__(self, name, score): self.name = name self.score = score
View Code
限制訪問:如果在執行個體的變數前加上兩個底線,那麼此變數就被視為私人變數,只有內部可訪問,外部需要通過方法訪問,
class Student(object): def __init__(self, name, score): self.__name = name self.__score = score def print_score(self): print(‘%s: %s‘ % (self.__name, self.__score))
>>> bart = Student(‘Bart Simpson‘, 98)>>> bart.__nameTraceback (most recent call last): File "<stdin>", line 1, in <module>AttributeError: ‘Student‘ object has no attribute ‘__name‘
Python中,變數名類似__xxx__的,也就是以雙底線開頭,並且以雙底線結尾的,是特殊變數,特殊變數是可以直接存取的,不是private變數,所以,不能用__name__、__score__這樣的變數名。
不能直接存取__name是因為Python解譯器對外把__name變數改成了_Student__name,所以,仍然可以通過_Student__name來訪問__name變數:但是強烈建議你不要這麼幹,因為不同版本的Python解譯器可能會把__name改成不同的變數名。
>>> bart = Student(‘Bart Simpson‘, 98)>>> bart.get_name()‘Bart Simpson‘>>> bart.__name = ‘New Name‘ # 設定__name變數!>>> bart.__name‘New Name‘
View Code
外部代碼“成功”地設定了__name變數,但實際上這個__name變數和class內部的__name變數不是一個變數!內部的__name變數已經被Python解譯器自動改成了_Student__name,而外部代碼給bart新增了一個__name變數。不信試試:
>>> bart.get_name() # get_name()內部返回self.__name‘Bart Simpson‘
繼承多態類似與java
擷取對象的資訊
使用type()函數來判斷對象的類型\
如果要獲得一個對象的所有屬性和方法,可以使用dir()函數,它返回一個包含字串的list,比如,獲得一個str對象的所有屬性和方法:
>>> dir(‘ABC‘)[‘__add__‘, ‘__class__‘, ‘__contains__‘, ‘__delattr__‘, ‘__dir__‘, ‘__doc__‘, ‘__eq__‘, ‘__format__‘, ‘__ge__‘, ‘__getattribute__‘, ‘__getitem__‘, ‘__getnewargs__‘, ‘__gt__‘, ‘__hash__‘, ‘__init__‘, ‘__iter__‘, ‘__le__‘, ‘__len__‘, ‘__lt__‘, ‘__mod__‘, ‘__mul__‘, ‘__ne__‘, ‘__new__‘, ‘__reduce__‘, ‘__reduce_ex__‘, ‘__repr__‘, ‘__rmod__‘, ‘__rmul__‘, ‘__setattr__‘, ‘__sizeof__‘, ‘__str__‘, ‘__subclasshook__‘, ‘capitalize‘, ‘casefold‘, ‘center‘, ‘count‘, ‘encode‘, ‘endswith‘, ‘expandtabs‘, ‘find‘, ‘format‘, ‘format_map‘, ‘index‘, ‘isalnum‘, ‘isalpha‘, ‘isdecimal‘, ‘isdigit‘, ‘isidentifier‘, ‘islower‘, ‘isnumeric‘, ‘isprintable‘, ‘isspace‘, ‘istitle‘, ‘isupper‘, ‘join‘, ‘ljust‘, ‘lower‘, ‘lstrip‘, ‘maketrans‘, ‘partition‘, ‘replace‘, ‘rfind‘, ‘rindex‘, ‘rjust‘, ‘rpartition‘, ‘rsplit‘, ‘rstrip‘, ‘split‘, ‘splitlines‘, ‘startswith‘, ‘strip‘, ‘swapcase‘, ‘title‘, ‘translate‘, ‘upper‘, ‘zfill‘]
僅把屬性和方法列出來是不夠的,配合getattr()、setattr()以及hasattr(),我們可以直接操作一個對象的狀態:
>>> hasattr(obj, ‘x‘) # 有屬性‘x‘嗎?True>>> obj.x9>>> hasattr(obj, ‘y‘) # 有屬性‘y‘嗎?False>>> setattr(obj, ‘y‘, 19) # 設定一個屬性‘y‘>>> hasattr(obj, ‘y‘) # 有屬性‘y‘嗎?True>>> getattr(obj, ‘y‘) # 擷取屬性‘y‘19>>> obj.y # 擷取屬性‘y‘19
執行個體屬性和類屬性
如下定義一個類屬性,可以同過執行個體訪問,也可以同類類名.屬性名稱訪問,但是如果類屬性名稱和執行個體屬性名稱相同的話,執行個體屬性名稱會覆蓋了類屬性。
class Student(object):
name = ‘Student‘
python第六天物件導向的編程