python面向物件的基礎語法
阿新 • • 發佈:2020-09-02
目標
dir
內建函式- 定義簡單的類(只包含方法)
- 方法中的
self
引數 - 初始化方法
- 內建方法和屬性
01.dir
內建函式(知道)
提示__方法名__
格式的方法是Python
提供的內建方法 / 屬性,稍後會給大家介紹一些常用的 內建方法 / 屬性
序號 | 方法名 | 型別 | 作用 |
---|---|---|---|
01 | __new__ |
方法 | 建立物件時,會被自動呼叫 |
02 | __init__ |
方法 | 物件被初始化時,會被自動呼叫 |
03 | __del__ |
方法 | 物件被從記憶體中銷燬前,會被自動呼叫 |
04 | __str__ |
方法 | 返回物件的描述資訊,print 函式輸出使用 |
提示利用好dir()
函式,在學習時很多內容就不需要死記硬背了
02. 定義簡單的類(只包含方法)
面向物件是更大的封裝,在一個類中 封裝 多個方法,這樣通過這個類創建出來的物件,就可以直接呼叫這些方法了!
2.1 定義只包含方法的類
- 在
Python
中要定義一個只包含方法的類,語法格式如下:
class 類名: def 方法1(self, 引數列表): pass def 方法2(self, 引數列表): pass
- 方法的定義格式和之前學習過的函式幾乎一樣
- 區別在於第一個引數必須是
self
,大家暫時先記住,稍後介紹self
- 注意:類名的 命名規則 要符合大駝峰命名法
2.2 建立物件
- 當一個類定義完成之後,要使用這個類來建立物件,語法格式如下:
物件變數 = 類名()
2.3 第一個面向物件程式
需求
- 小貓愛吃魚,小貓要喝水
分析
- 定義一個貓類
Cat
- 定義兩個方法
eat
和drink
- 按照需求 —— 不需要定義屬性
class Cat: """這是一個貓類""" def eat(self): print("小貓愛吃魚") def drink(self): print("小貓在喝水") tom = Cat() tom.drink() tom.eat()
引用概念的強調
在面向物件開發中,引用的概念是同樣適用的!
- 在
Python
tom
變數中 仍然記錄的是物件在記憶體中的地址 - 也就是
tom
變數引用了新建的貓物件 - 使用
print
輸出物件變數,預設情況下,是能夠輸出這個變數引用的物件是由哪一個類建立的物件,以及在記憶體中的地址(十六進位制表示)
提示:在計算機中,通常使用十六進位制表示記憶體地址
- 十進位制和十六進位制都是用來表達數字的,只是表示的方式不一樣
- 十進位制和十六進位制的數字之間可以來回轉換
%d
可以以10 進位制輸出數字%x
可以以16 進位制輸出數字
03. 方法中的self
引數
3.1 案例改造 —— 給物件增加屬性
- 在
Python
中,要給物件設定屬性,非常的容易,但是不推薦使用- 因為:物件屬性的封裝應該封裝在類的內部
- 只需要在類的外部的程式碼中直接通過
.
設定一個屬性即可
注意:這種方式雖然簡單,但是不推薦使用!
tom.name = "Tom" ... lazy_cat.name = "大懶貓"
3.2 使用self
在方法內部輸出每一隻貓的名字
由哪一個物件呼叫的方法,方法內的
self
就是哪一個物件的引用
- 在類封裝的方法內部,
self
就表示當前呼叫方法的物件自己 - 呼叫方法時,程式設計師不需要傳遞
self
引數 - 在方法內部
- 可以通過
self.
訪問物件的屬性 - 也可以通過
self.
呼叫其他的物件方法
- 可以通過
- 改造程式碼如下:
class Cat: def eat(self): print("%s 愛吃魚" % self.name) tom = Cat() tom.name = "Tom" tom.eat() lazy_cat = Cat() lazy_cat.name = "大懶貓" lazy_cat.eat()
- 在類的外部,通過
變數名.
訪問物件的屬性和方法 - 在類封裝的方法中,通過
self.
訪問物件的屬性和方法
04. 初始化方法
4.1 之前程式碼存在的問題 —— 在類的外部給物件增加屬性
- 將案例程式碼進行調整,先呼叫方法 再設定屬性,觀察一下執行效果
tom = Cat() tom.drink() tom.eat() tom.name = "Tom" print(tom)
- 程式執行報錯如下:
AttributeError: 'Cat' object has no attribute 'name' 屬性錯誤:'Cat' 物件沒有 'name' 屬性
提示
- 在日常開發中,不推薦在類的外部給物件增加屬性
- 如果在執行時,沒有找到屬性,程式會報錯
- 物件應該包含有哪些屬性,應該封裝在類的內部
4.2 初始化方法
- 當使用
類名()
建立物件時,會自動執行以下操作:- 為物件在記憶體中分配空間—— 建立物件
- 為物件的屬性設定初始值—— 初始化方法(
init
)
- 這個初始化方法就是
__init__
方法,__init__
是物件的內建方法
__init__
方法是專門用來定義一個類具有哪些屬性的方法!
在Cat
中增加__init__
方法,驗證該方法在建立物件時會被自動呼叫
class Cat: """這是一個貓類""" def __init__(self): print("初始化方法")
4.3 在初始化方法內部定義屬性
- 在
__init__
方法內部使用self.屬性名 = 屬性的初始值
就可以定義屬性 - 定義屬性之後,再使用
Cat
類建立的物件,都會擁有該屬性
class Cat: def __init__(self): print("這是一個初始化方法") # 定義用 Cat 類建立的貓物件都有一個 name 的屬性 self.name = "Tom" def eat(self): print("%s 愛吃魚" % self.name) # 使用類名()建立物件的時候,會自動呼叫初始化方法 __init__ tom = Cat() tom.eat()
4.4 改造初始化方法 —— 初始化的同時設定初始值
- 在開發中,如果希望在建立物件的同時,就設定物件的屬性,可以對
__init__
方法進行改造- 把希望設定的屬性值,定義成
__init__
方法的引數 - 在方法內部使用
self.屬性 = 形參
接收外部傳遞的引數 - 在建立物件時,使用
類名(屬性1, 屬性2...)
呼叫 -
class Cat: def __init__(self, name): print("初始化方法 %s" % name) self.name = name ... tom = Cat("Tom") ... lazy_cat = Cat("大懶貓")
- 把希望設定的屬性值,定義成
05. 內建方法和屬性
序號 | 方法名 | 型別 | 作用 |
---|---|---|---|
01 | __del__ |
方法 | 物件被從記憶體中銷燬前,會被自動呼叫 |
02 | __str__ |
方法 | 返回物件的描述資訊,print 函式輸出使用 |
5.1__del__
方法(知道)
-
在
Python
中- 當使用
類名()
建立物件時,為物件分配完空間後,自動呼叫__init__
方法 - 當一個物件被從記憶體中銷燬前,會自動呼叫
__del__
方法
- 當使用
-
應用場景
__init__
改造初始化方法,可以讓建立物件更加靈活__del__
如果希望在物件被銷燬前,再做一些事情,可以考慮一下__del__
方法
-
生命週期
- 一個物件從呼叫
類名()
建立,生命週期開始 - 一個物件的
__del__
方法一旦被呼叫,生命週期結束 - 在物件的生命週期內,可以訪問物件屬性,或者讓物件呼叫方法
-
class Cat: def __init__(self, new_name): self.name = new_name print("%s 來了" % self.name) def __del__(self): print("%s 去了" % self.name) # tom 是一個全域性變數 tom = Cat("Tom") print(tom.name) # del 關鍵字可以刪除一個物件 del tom print("-" * 50)
- 一個物件從呼叫
5.2__str__
方法
- 在
Python
中,使用print
輸出物件變數,預設情況下,會輸出這個變數引用的物件是由哪一個類建立的物件,以及在記憶體中的地址(十六進位制表示) - 如果在開發中,希望使用
print
輸出物件變數時,能夠列印自定義的內容,就可以利用__str__
這個內建方法了
注意:
__str__
方法必須返回一個字串
class Cat: def __init__(self, new_name): self.name = new_name print("%s 來了" % self.name) def __del__(self): print("%s 去了" % self.name) def __str__(self): return "我是小貓:%s" % self.name tom = Cat("Tom") print(tom)
class cat: cat_name="111" def Set_Cat_name(self,name): self.cat_name=name; def showinfo(self): return self.cat_name; t1=cat() t2=cat() print(t1.showinfo()) t1.Set_Cat_name("mimi"); t2.Set_Cat_name('miaomiao'); print("cat1 is name:%s"%t1.showinfo()) print("cat2 is name:%s"%t2.showinfo())