前言
剛剛接觸編程的時候,我們往往按照時間順序思考某一個問題該如何解決,采取不同的方法(函數)依次實現目標,也就是所謂的“面向過程編程”;
與之不同的是,實際生活中存在大量數據本身和某一種屬性或方法緊密結合的情況,比如學生的學費與學制、學校水平掛鉤;工人的工資和工種、工作年限掛鉤,這時為了方便管理我們可以采用一個對象(工人群體、學生群體)對應不同的屬性(工種、學制)對應不同的方法(學費、工資如何計算)的方式管理數據,也就是“面向對象編程”
面向過程:以過程(或函數)為中心,強調任務的完成,通過對數據和功能的分離來解決問題。代碼組織通常圍繞函數和過程流。
面向對象:以對象為中心,強調通過封裝數據和行為(方法)來模擬現實世界。對象是類的實例,類定義了對象的屬性和方法。
實例
本例來源于B站up主:林粒粒呀
假設你管理著一家公司的工人數據庫,其中有許多工人(對象),他們有姓名和工號兩種屬性,你希望有這樣一個函數,每次調用都可以輸出他們的姓名和工號;此外,工人分為全職工人和兼職工人,你希望還有一個函數,每次調用可以輸出工人的月薪:全職工人按月發薪,兼職工人按日發薪,最終都以月薪的形式展現
我們可以使用class關鍵字定義一個Worker類:
該類下面的每一個對象具有姓名和工號兩個自身屬性
name和work_id是我們調用Worker類時從外部傳入的變量,要注意給到self.name和self.work_id下使之成為類下屬對象的自身屬性, __init__函數是構造函數,必須要有self參數
print_info方法可以查看工人的姓名和工號
class Worker:
def __init__(self, name, work_id): # 名字好像只能是字符串
self.name = name
self.work_id = work_id
def print_info(self):
print(f"姓名:{self.name} 工號:{self.work_id}")
再進一步,分全職工人和兼職工人,他們對應著不同的薪資計算方法
FT是Full-time的簡寫, PT是Part-time的簡寫
這里可以用到類繼承,無論是全職還是兼職工人,都是工人(父類)的子類,所以工號和姓名這兩個屬性以及打印工號和姓名的函數(print_info)可以直接從Worker類下面繼承,只需要在各自類名后的括號里放入父類名Worker,并調用super()初始化繼承自父類的兩個屬性就可以了。
我們希望得到全職工人和兼職工人各自的月薪計算方法
由于全職工人本來就按月發薪,所以直接把monthly_salary傳給FTWorker類,再定義一個函數calculate_monthly_pay_FT返回monthly_salary就可以了,最后定義一下print_info_FT函數,格式化輸出姓名、工號和月收入
class FTWorker(Worker):
def __init__(self, name, work_id, monthly_salary):
super().__init__(name, work_id)
self.monthly_salary = monthly_salary
def calculate_monthly_pay_FT(self):
return self.monthly_salary # 如果不返回任何值就會出現None
def print_info_FT(self):
print(f"{self.name}(工號{self.work_id})的月收入是{self.monthly_salary}")
兼職工人按日發薪,所以想知道月薪需要加上工作時長work_time參數,再把兩者相乘的結果傳給PT_salary變量并返回,類似的,我們也定義一個print_info_PT函數格式化輸出姓名、工號和月收入即可,至此兩個子類都已經封裝好了
class PTWorker(Worker):
def __init__(self, name, work_id, daily_salary, work_time):
super().__init__(name, work_id)
self.daily_salary = daily_salary
self.work_time = work_time
def calculate_monthly_pay_PT(self):
PT_salary = self.work_time * self.daily_salary
return PT_salary
def print_info_PT(self):
print(f"{self.name}(工號{self.work_id})的月收入是{self.work_time * self.daily_salary}")
向類中添加對象
參數不要傳漏了,兼職工人有一個工時
lin = PTWorker("lzy", 34, 500, 8)
zeng = FTWorker("zcy", 1, 8000)
lyf = PTWorker("lyf", 9, 100, 14)
最后調用類下的方法,看看結果
lin.print_info()
lin.print_info_PT()
zeng.print_info()
zeng.print_info_FT()
lyf.print_info()
lyf.print_info_PT()