Python類與實例的使用詳解
視頻
使用類和實例
你可以使用類來模擬現(xiàn)實世界中的很多情景。類編寫好后,你的大部分時間都將花在使用根據(jù)類創(chuàng)建的實例上。你需要執(zhí)行的一個重要任務是修改實例的屬性。
Car類
下面來編寫一個表示汽車的類,它存儲了有關汽車的信息,還有一個匯總這些信息的方法:
car.py
class Car(): """一次模擬汽車的簡單嘗試""" def __init__(self, make, model, year): """初始化描述汽車的屬性""" self.make = make self.model = model self.year = year def get_descriptive_name(self): """返回整潔的描述性信息""" long_name = str(self.year) + ' ' + self.make + ' ' + self.model return long_name.title() my_new_car = Car('audi', 'a4', 2016) print(my_new_car.get_descriptive_name())
第3行:定義了方法__init__()
。第一個形參為self;方法中包含了另外三個形參:make、model和year。方法__init__()
接受這些形參的值,并將它們存儲在根據(jù)這個類創(chuàng)建的實例的屬性中。創(chuàng)建新的Car實例時,需要指定其制造商、型號和生產(chǎn)年份。
第8行:定義了名為get_descriptive_name()
的方法,它使用屬性year、make和model創(chuàng)建一個對汽車進行描述的字符串。為了訪問屬性的值,使用了self.make
、self.model
和self.year
。
第12行,根據(jù)Car類創(chuàng)建了一個實例,并將其存儲到變量my_new_car中。接下來,調(diào)用方法get_descriptive_name()
,指出是一輛什么樣的汽車:
2016 Audi A4
為讓這個類更有趣,下面給它添加一個隨時間變化的屬性,它存儲汽車的總里程。
類中的每個屬性都必須有初始值,哪怕這個值是0或空字符串。在有些情況下,如設置默認值時,需要在方法__init__()
內(nèi)指定初始值;這樣就無需包含為它提供初始值的形參。
下面來添加一個名為odometer_reading
屬性,其初始值總是為0。還添加了一個名為read_odometer()
的方法,用于讀取汽車的里程表:
class Car(): """一次模擬汽車的簡單嘗試""" def __init__(self, make, model, year): """初始化描述汽車的屬性""" self.make = make self.model = model self.year = year self.odometer_reading = 0 def get_descriptive_name(self): """返回整潔的描述性信息""" long_name = str(self.year) + ' ' + self.make + ' ' + self.model return long_name.title() def read_odometer(self): """打印一條指出汽車里程的消息""" print("This car has " + str(self.odometer_reading) + " miles on it.") my_new_car = Car('audi', 'a4', 2016) print(my_new_car.get_descriptive_name()) my_new_car.read_odometer()
現(xiàn)在,當創(chuàng)建新實例時,將像前一個示例一樣以屬性的方式存儲制造商、型號和生產(chǎn)年份。接下來,Python將創(chuàng)建一個名為odometer_reading
的屬性,并將其初始值設置為0。
第13行:還定義了一個名為read_odometer()的方法,用它能夠輕松地獲悉汽車的里程。
一開始汽車的里程為0:
2016 Audi A4
This car has 0 miles on it.
修改屬性值
出售時里程表讀數(shù)為0的汽車并不多,因此需要一個修改該屬性的值的途徑。
可以以三種不同的方式修改屬性的值:直接通過實例進行修改;通過方法進行設置;通過方法進行遞增(增加特定的值)。下面依次介紹這些方法。
直接修改屬性的值
要修改屬性的值,最簡單的方式是通過實例直接訪問它。下面的代碼直接將里程表讀數(shù)設置為23:
my_new_car = Car('audi', 'a4', 2016) print(my_new_car.get_descriptive_name()) my_new_car.odometer_reading = 23 my_new_car.read_odometer()
第4行,使用句點表示法來直接訪問并設置汽車的屬性odometer_reading
。這行代碼讓Python在實例my_new_car中找到屬性odometer_reading,并將該屬性的值設置為23:
2016 Audi A4
This car has 23 miles on it.
有時候需要像這樣直接訪問屬性,但其他時候需要編寫對屬性進行更新的方法。
通過方法修改屬性的值
如果有替你更新屬性的方法,將很方便。這樣,你就無需直接訪問屬性,而可將值傳遞給一個方法,由它在內(nèi)部進行更新。
下面的示例演示了一個名為update_odometer()的方法:
class Car(): """一次模擬汽車的簡單嘗試""" def __init__(self, make, model, year): """初始化描述汽車的屬性""" self.make = make self.model = model self.year = year self.odometer_reading = 0 def get_descriptive_name(self): """返回整潔的描述性信息""" long_name = str(self.year) + ' ' + self.make + ' ' + self.model return long_name.title() def read_odometer(self): """打印一條指出汽車里程的消息""" print("This car has " + str(self.odometer_reading) + " miles on it.") def update_odometer(self, mileage): """將里程表讀數(shù)設置為指定的值""" self.odometer_reading = mileage my_new_car = Car('audi', 'a4', 2016) print(my_new_car.get_descriptive_name()) my_new_car.update_odometer(23) my_new_car.read_odometer()
對Car類所做的唯一修改是在第16行添加了方法update_odometer()
。這個方法接受一個里程值,
并將其存儲到self.odometer_reading中。第23行,調(diào)用了update_odometer()
,并向它提供了 實參23。它將里程表讀數(shù)設置為23;而方法read_odometer()
打印該讀數(shù):
2016 Audi A4
This car has 23 miles on it.
可對方法update_odometer()
進行擴展,使其在修改里程表讀數(shù)時做些額外的工作。下面來添加一些邏輯,禁止任何人將里程表讀數(shù)往回調(diào):
class Car(): """一次模擬汽車的簡單嘗試""" def __init__(self, make, model, year): """初始化描述汽車的屬性""" self.make = make self.model = model self.year = year self.odometer_reading = 0 def get_descriptive_name(self): """返回整潔的描述性信息""" long_name = str(self.year) + ' ' + self.make + ' ' + self.model return long_name.title() def read_odometer(self): """打印一條指出汽車里程的消息""" print("This car has " + str(self.odometer_reading) + " miles on it.") def update_odometer(self, mileage): """ 將里程表讀數(shù)設置為指定的值 禁止將里程表讀數(shù)往回調(diào) """ if mileage >= self.odometer_reading: self.odometer_reading = mileage else: print("You can't roll back an odometer!")
現(xiàn)在,update_odometer()
在修改屬性前檢查指定的讀數(shù)是否合理。如果新指定的里程(mileage)大于或等于原來的里程(self.odometer_reading
),就將里程表讀數(shù)改為新指定的里程;否則就發(fā)出警告,指出不能將里程表往回撥。
通過方法對屬性的值進行遞增
有時候需要將屬性值遞增特定的量,而不是將其設置為全新的值。假設購買了一輛二手車,且從購買到登記期間增加了100英里的里程,下面的方法讓能夠傳遞這個增量,并相應地增加里程表讀數(shù):
class Car(): --snip-- def increment_odometer(self, miles): """將里程表讀數(shù)增加指定的量""" self.odometer_reading += miles my_used_car = Car('subaru', 'outback', 2013) print(my_used_car.get_descriptive_name()) my_used_car.update_odometer(23500) my_used_car.read_odometer() my_used_car.increment_odometer(100) my_used_car.read_odometer()
第3行:新增的方法increment_odometer()
接受一個單位為英里的數(shù)字,并將其加入到self.odometer_reading
中。第8行,創(chuàng)建了一輛二手車——my_used_car
。第10行,調(diào)用
方法update_odometer()
并傳入23500,將這輛二手車的里程表讀數(shù)設置為23500。第12行,調(diào)
用increment_odometer()
并傳入100,以增加從購買到登記期間行駛的100英里:
2013 Subaru Outback
This car has 23500 miles on it.
This car has 23600 miles on it.
你可以輕松地修改這個方法,以禁止增量為負值,從而防止有人利用它來回撥里程表。
注意: 你可以使用類似于上面的方法來控制用戶修改屬性值(如里程表讀數(shù))的方式,但能夠訪問程序的人都可以通過直接訪問屬性來將里程表修改為任何值。要確保安全,除了進行類似于前面的基本檢查外,還需特別注意細節(jié)。
到此這篇關于Python類與實例的使用詳解的文章就介紹到這了,更多相關Python類與實例內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python3.9最新版下載與安裝圖文教程詳解(Windows系統(tǒng)為例)
這篇文章主要介紹了Python3.9最新版下載與安裝圖文教程詳解,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11Python生命游戲?qū)崿F(xiàn)原理及過程解析(附源代碼)
這篇文章主要介紹了Python生命游戲?qū)崿F(xiàn)原理及過程解析(附源代碼),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-08-08Python threading模塊condition原理及運行流程詳解
這篇文章主要介紹了Python threading模塊condition原理及運行流程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-10-10Keras搭建分類網(wǎng)絡平臺VGG16?MobileNet?ResNet50
這篇文章主要為大家介紹了Keras搭建分類網(wǎng)絡平臺VGG16?MobileNet?ResNet50,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05Python接口自動化淺析logging日志原理及模塊操作流程
這篇文章主要為大家介紹了Python接口自動化系列文章淺析logging日志原理及模塊操作流程,文中詳細說明了為什么需要日志?日志是什么?以及日志用途等基本的原理2021-08-08詳解Python中RegEx在數(shù)據(jù)處理中的應用
正則表達式(Regular?Expressions,簡稱?RegEx)是一種強大的文本匹配和搜索工具,它在數(shù)據(jù)處理、文本解析和字符串操作中發(fā)揮著關鍵作用,下面就跟隨小編一起來了解一下RegEx的具體使用吧2024-01-01