Python基礎第四課

來源:互聯網
上載者:User

標籤:err   學生   分數   字典   包括   pre   表的操作   not found   取值   

github部落格傳送門
csdn部落格傳送門

物件導向

對新手來說這塊比較難,建議大家快速閱讀一下概念,然後無論會不會先抄幾道題(注意:必須手打)建議3道簡單的題刷三遍一共九遍之後再看概念容易懂一些.
說的高深點,物件導向就是對記憶體指標的指向的改寫,不過今天我們不討論那麼深.還是來點簡單的.照顧一下新手.

類(Class): 用來描述具有相同的屬性和方法的對象的集合。它定義了該集合中每個對象所共有的屬性和方法。對象是類的執行個體.
(自我形象化理解(協助新手理解):一個人背了個空包,什麼也沒有裝,我們就可以把這個空包比喻為:.)

類變數:類變數在整個執行個體化的對象中是公用的。類變數定義在類中且在函數體之外。類變數通常不作為執行個體變數使用。
(自我形象化理解(協助新手理解):一個人背了個包,包上有很多屬性,比如包容量,所有往包裡放的東西都可以使用這個容器.每放一個東西這個容量就會減少,每拿出一個東西這個容量就會增加.我們稱這個 包容量/包的屬性 為這個 空包/類 的:類變數.)

方法:類中定義的函數。
(自我形象化理解(協助新手理解):假如這個空包裡裝了一些工具 比如 鎚子,帕子,手機,錢包等等能裝的東西 然後鎚子能用來敲東西,帕子能用來洗臉擦汗等等 那麼我們就稱這些工具為:方法.)

執行個體化:建立一個類的執行個體,類的具體對象。
(自我形象化理解(協助新手理解):一個人背了個包,包裡的 工具/方法 需要人來使用才有意義吧.這個人就相當於可以將這個包裡工具拿來使用了.這個人就相當於 執行個體化/類的執行個體化 唯一和平時不一樣的是 每執行個體化一個對象 也就是多一個人使用這個包 就是將這個包複製了一份 大家可以共同並且同時使用同一個 工具)

執行個體變數:定義在方法中的變數,只作用於當前執行個體的類.
(自我形象化理解(協助新手理解):定義在每個方法內的變數.每當執行個體化一個變數,每個人用 工具/方法 的方式不同,也就是說這個工具的使用方式 就是當前使用這個人的 特有變數/執行個體變數)

繼承:即一個衍生類別(derived class)繼承基類(base class)的欄位和方法。繼承也允許把一個衍生類別的對象作為一個基類對象對待。例如,有這樣一個設計:一個Dog類型的對象派生自Animal類,這是類比"是一個(is-a)"關係(Dog是一個Animal)
(自我形象化理解(協助新手理解):一個人背了個包,包裡有很多工具,當他將這個包給他兒子,他兒子既可以使用包裡的工具,也可以自己添加一些新的工具並使用 這個就可以稱為:繼承.)

方法重寫:如果從父類繼承的方法不能滿足子類的需求,可以對其進行改寫,這個過程叫方法的覆蓋(override),也稱為方法的重寫。
(自我形象化理解(協助新手理解):當兒子從父親那裡繼承了包之後 他覺得現在這個鎚子不太好用,決定重新換個鎚子頭或者鎚子把 這就稱之為:方法的重寫.)

資料成員:類變數或者執行個體變數用於處理類及其執行個體對象的相關的資料.
(自行理解,這塊用的少.)

對象:通過類定義的資料結構執行個體。對象包括兩個資料成員(類變數和執行個體變數)和方法.
(自行理解,這塊用的少.)

定義一個類的格式
class 類名:                        # 建立一個類必寫    類變數名 = 類變數的值            # 非必需    def 方法名1:                   # 基本必需 不然建立這個類就沒有意義了        執行個體變數名 = 執行個體變數的值    # 非必需        方法塊    .    .    .    def 方法名N:        方法塊# 執行個體化這個類變數名People = 類名()    # 這樣就執行個體化了一個對象 相當於我們之前說的建立了一個人使用這個包.變數名People.方法名1()   # 這樣就可以調用 執行個體化對象的方法了.

初始化方式

class Fun:    # __init__這個方法會在你建立執行個體的時候自動執行    def __init__(self,name): # 新手可能會對self這個詞有所疑惑,我只能建議你,每個方法都要寫self,並且是寫在第一個參數位置的,新手直接無視 也就是當作沒有self這個詞就可以了.        print(‘初始化這個執行個體對象的人是:{}‘.format(name))# 我們執行個體化一下這個類fun = Fun(‘Mrzhang‘)# 然後就會自動列印初始化這個執行個體對象的人是:Mrzhang    #就將Mrzhang傳給這個方法了.

繼承的格式

class Animal:   # 建立了一個動物animal類 動物都可以吃    def eat(self):        print(‘Animal is eat‘)class Dog(Animal):    # 建立了一個dog類 繼承animal    def run(self):        print(‘Dog is run‘) # 也就是說 dog 類既有 run方法 也有 eat吃 方法dog = Dog()dog.eat()dog.run()# 輸出Animal is eatDog is run

基本的就講這麼多 後面給三道我當初學習的時候練的題練三遍.不管看懂沒看懂先照著敲三遍 再回頭來看概念就清晰了.

第一題
# coding=utf-8"""一:定義一個學生類。有下面的類屬性:1 姓名2 年齡3 成績(語文,數學,英語)[每課成績的類型為整數]類方法:1 擷取學生的姓名:get_name() 傳回型別:str2 擷取學生的年齡:get_age() 傳回型別:int3 返回3門科目中最高的分數。get_course() 傳回型別:int寫好類以後,可以定義2個同學測試下:zm = Student(‘zhangming‘,20,[69,88,100])返回結果:zhangming20100"""class Student(object):    def __init__(self, name, age, scores):        self.name = name        self.age = age        self.scores = scores    def get_name(self):        return self.name    def get_age(self):        return self.age    def get_course(self):        return max(self.scores)zm = Student(‘zhangming‘, 20, [69, 88, 100])print(zm.get_name())print(zm.get_age())print(zm.get_course())# 輸出下面這些數值就是沒有問題了zhangming20100
第二題
"""二:定義一個字典類:dictclass。完成下面的功能:dict = dictclass({你需要操作的字典對象})1 刪除某個keydel_dict(key)2 判斷某個鍵是否在字典裡,如果在返回鍵對應的值,不存在則返回"not found"get_dict(key)3 返回鍵組成的列表:傳回型別;(list)get_key()4 合并字典,並且返回合并後字典的values組成的列表。傳回型別:(list)update_dict({要合并的字典})"""class dictclass(object):    def __init__(self, dict):        self.dict = dict    def get_dict(self, key):        if key in self.dict:            return self.dict[key]        return ‘not found‘    def del_dict(self, key):        if key in self.dict:            self.dict.pop(key)        else:            return ‘no that key‘    def get_key(self):        return self.dict.keys()    def updata_dict(self, dict2):        self.dict = dict(self.dict, **dict2)        return self.dict.values()A = dictclass({‘a‘: 1, ‘b‘: 2})print(A.get_dict(‘c‘))print(A.del_dict(‘c‘))print(A.get_key())print(A.updata_dict({‘c‘: 3, ‘d‘: 4}))# 關於刪除字典中的元素# pop 刪除並返回對應的value值B = {‘a‘: 1, ‘b‘: 2}print(B.pop(‘b‘))print(B)# del void不傳回值C = {‘a‘: 1, ‘b‘: 2}del C[‘a‘]print(C)# del dict 刪除字典,不存在這個字典# dict.clear()刪除字典內所有元素但字典還是存在只是沒有元素D = {‘a‘: 1, ‘b‘: 2, ‘c‘: 3}D.clear()# 關於合并字典A = {‘a‘: 1, ‘b‘: 2, ‘c‘: 3}B = {‘d‘: 4, ‘e‘: 5, ‘f‘: 6}C = A.update(B)D = dict(A, **B)  # 這種合并方法會比上一種快很多對於重複的key,B會覆蓋A# 輸出下列值就沒有問題:not foundno that keydict_keys([‘a‘, ‘b‘])dict_values([1, 2, 3, 4])2{‘a‘: 1}{‘b‘: 2}
第三題
"""定義一個列表的操作類:Listinfo包括的方法:1 列表元素添加: add_key(keyname)  [keyname:字串或者整數類型]2 列表元素取值:get_key(num) [num:整數類型]3 列表合并:update_list(list)      [list:清單類型]4 刪除並且返回最後一個元素:del_key()list_info = Listinfo([44,222,111,333,454,‘sss‘,‘333‘])"""class Listinfo(object):    def __init__(self, list_val):        self.varlist = list_val    def add_key(self, key_name):        if isinstance(key_name, (str, int)):            self.varlist.append(key_name)            return self.varlist        else:            return ‘error‘    def get_key(self, num):        if num >= 0 and num < len(self.varlist):            return self.varlist[num]        else:            return ‘error‘    def update_list(self, List_et):        self.varlist.extend(List_et)        return self.varlist    def del_key(self):        if len(self.varlist) >= 0:            return self.varlist.pop(-1)        else:            return ‘error‘list_info = Listinfo([44, 222, 111, 333, 454, ‘sss‘, ‘333‘])print(list_info.add_key(‘1111‘))print(list_info.get_key(4))print(list_info.update_list([‘1‘, ‘2‘, ‘3‘]))print(list_info.del_key())# 輸出下列資料就沒有問題:[44, 222, 111, 333, 454, ‘sss‘, ‘333‘, ‘1111‘]454[44, 222, 111, 333, 454, ‘sss‘, ‘333‘, ‘1111‘, ‘1‘, ‘2‘, ‘3‘]3

如果大家練完了 三遍這三道題 我相信 大家對物件導向的基本操作有了一定的瞭解了. 建議大家再回頭看看物件導向的概念.剩下的 小問題就在實戰中去解決吧.

Python基礎第四課

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.