一文帶你全面理解Python中的self
對于初學(xué)Python的同學(xué)來說,在class中經(jīng)??吹絪elf。那么,到底self是個啥?
這得從面向?qū)ο笳f起。Python從設(shè)計之初就已經(jīng)是一門面向?qū)ο蟮恼Z言,在Python中創(chuàng)建一個類和對象是很容易的。
比如,下面的代碼片段:定義了一個類Employee
#!/usr/bin/python # -*- coding: UTF-8 -*- class Employee: '所有員工的基類' empCount = 0 def __init__(self, name, salary): self.name = name self.salary = salary Employee.empCount += 1 def displayCount(self): print("Total Employee %d" % Employee.empCount) def displayEmployee(self): print("Name : ", self.name, ", Salary: ", self.salary)
類,其實就是定義現(xiàn)實世界中的事物,人、物、等等,任何名詞類的東西。比如上面定義的員工。
定義只是定義,我們定義了員工具有姓名、薪資這樣的屬性,但是具體到某個員工,其這些屬性值一般都不一樣。如何描述某個具體的員工?
有了定義,我們就可以創(chuàng)建實例了,這樣就可以描述某個具體的員工了。其他編程語言中一般用關(guān)鍵字new來創(chuàng)建類的實例,但是在 Python 中并沒有這個關(guān)鍵字,類的實例化類似于函數(shù)調(diào)用方式。
下面的代碼:實例化Employee類
"創(chuàng)建 Employee 類的第一個對象" emp1 = Employee("張三", 2000) "創(chuàng)建 Employee 類的第二個對象" emp2 = Employee("王五", 5000)
注意:init()方法是一種特殊的方法,被稱為類的構(gòu)造函數(shù)或初始化方法,當創(chuàng)建這個類的實例的時候,就會調(diào)用該方法
而self是什么?self其實是一個占位符,代表類的實例。 當我們用上面的代碼創(chuàng)建emp1實例的時候,它代表的是emp1這個實例;當創(chuàng)建emp2的時候,代表的是emp2這個實例。
因此,當我們調(diào)用下面的實例方法的時候,會分別輸出實例的對應(yīng)屬性的值:
emp1.displayEmployee() emp2.displayEmployee()
Name : 張三 , Salary: 2000 Name : 王五 , Salary: 5000
self是與類的實例相關(guān)的。當然,類本身的一些屬性和方法,是不需要實例化也存在的,千萬不要搞混淆了。
比如,前面代碼中的自定義的類屬性empCount。以及,下面的介紹的內(nèi)置屬性。
Python類的內(nèi)置屬性
- dict : 類的屬性的集合:包括自定義的屬性
- doc :類的文檔字符串
- name: 類名
- module: 類定義所在的模塊
- bases : 類的所有父類構(gòu)成元素
執(zhí)行:
print("Employee.__doc__:", Employee.__doc__) print("Employee.__name__:", Employee.__name__) print("Employee.__module__:", Employee.__module__) print("Employee.__bases__:", Employee.__bases__) print("Employee.__dict__:", Employee.__dict__)
輸出:
Employee.__doc__: 所有員工的基類
Employee.__name__: Employee
Employee.__module__: __main__
Employee.__bases__: (<class 'object'>,)
Employee.__dict__: {'__module__': '__main__', '__doc__': '所有員工的基類', 'empCount': 2, '__init__': <function Employee.__init__ at 0x0000025F73518550>, 'displayCount': <function Employee.displayCount at 0x0000025F735185E0>, 'displayEmployee': <function Employee.displayEmployee at 0x0000025F73518670>, '__dict__': <attribute '__dict__' of 'Employee' objects>, '__weakref__': <attribute '__weakref__' of 'Employee' objects>}
還有一些Python中的內(nèi)置方法,在某種情況下,會自動執(zhí)行。
init
前面說過的,在實例化的時候,會被調(diào)用執(zhí)行
new
在__init__觸發(fā)前自動觸發(fā),調(diào)用該類時,方法是真正的類構(gòu)造方法,用于產(chǎn)生實例化對象(空屬性)。因此,可以重寫__new__方法來控制對象的產(chǎn)生過程
del
用于當對象的引用計數(shù)為0時自動調(diào)用。一般被垃圾回收處理時調(diào)用。
在class里面,是不是必須使用self
不一定,比如我們定義”靜態(tài)類“的時候:
class util: def checkEmployee(emp): if isinstance(emp, Employee): print("Name : ", emp.name, ", Salary: ", emp.salary) else: print("%s不是Employee" % emp)
假如,我們設(shè)計了一個工具類util:用來檢測傳入的參數(shù)是不是Employee類型,如果是的話,才進一步處理。
看下面的代碼片段:
emp3 = "李四" util.checkEmployee(emp1) util.checkEmployee(emp2) util.checkEmployee(emp3)
輸出:
Name : 張三 , Salary: 2000
Name : 王五 , Salary: 5000
到此這篇關(guān)于一文帶你全面理解Python中的self的文章就介紹到這了,更多相關(guān)Python self內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用keras實現(xiàn)Precise, Recall, F1-socre方式
這篇文章主要介紹了使用keras實現(xiàn)Precise, Recall, F1-socre方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06PyTorch中l(wèi)oading fbgemm.dll異常的解決辦法
PyTorch是一個深度學(xué)習(xí)框架,當我們在本地調(diào)試大模型時,可能會選用并安裝它,目前已更新至2.4版本,本文給大家介紹了PyTorch中l(wèi)oading fbgemm.dll異常的解決辦法,文中通過代碼和圖文介紹的非常詳細,需要的朋友可以參考下2024-08-08Python實現(xiàn)將n個點均勻地分布在球面上的方法
這篇文章主要介紹了Python實現(xiàn)將n個點均勻地分布在球面上的方法,涉及Python繪圖的技巧與相關(guān)數(shù)學(xué)函數(shù)的調(diào)用,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03純python實現(xiàn)機器學(xué)習(xí)之kNN算法示例
本篇文章主要介紹了純python實現(xiàn)機器學(xué)習(xí)之kNN算法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03Python中的正則表達式與JSON數(shù)據(jù)交換格式
正則表達式 是一個特殊的字符序列,一個字符串是否與我們所設(shè)定的這樣的字符序列,相匹配快速檢索文本、實現(xiàn)替換文本的操作。這篇文章主要介紹了Python中的正則表達式與JSON ,需要的朋友可以參考下2019-07-07python刪除列表元素del,pop(),remove()及clear()
這篇文章主要介紹了python刪除列表元素del,pop(),remove()及clear(),列表元素能增加就可以刪除,這里要給大家介紹的是刪除列表元素,具有一定的參考價值,需要的小伙伴可以參考一下2022-03-03