1. 程式人生 > >課後練習、十七

課後練習、十七

9-6 冰淇淋小店 :冰淇淋小店是一種特殊的餐館。編寫一個名為IceCreamStand 的類,讓它繼承你為完成練習9-1或練習9-4而編寫的Restaurant 類。這兩個版 本的Restaurant 類都可以,挑選你更喜歡的那個即可。新增一個名為flavors 的屬性,用於儲存一個由各種口味的冰淇淋組成的列表。編寫一個顯示這些冰淇淋 的方法。建立一個IceCreamStand 例項,並呼叫這個方法。

9-7 管理員 :管理員是一種特殊的使用者。編寫一個名為Admin 的類,讓它繼承你為完成練習9-3或練習9-5而編寫的User 類。新增一個名為privileges 的屬性,用 於儲存一個由字串(如"can add post" 、"can delete post" 、"can ban user" 等)組成的列表。編寫一個名為show_privileges() 的方法,它 顯示管理員的許可權。建立一個Admin 例項,並呼叫這個方法。

9-8 許可權 :編寫一個名為Privileges 的類,它只有一個屬性——privileges ,其中儲存了練習9-7 所說的字串列表。將方法show_privileges() 移到這 個類中。在Admin 類中,將一個Privileges 例項用作其屬性。建立一個Admin 例項,並使用方法show_privileges() 來顯示其許可權。

9-9 電瓶升級 :在本節最後一個electric_car.py版本中,給Battery 類新增一個名為upgrade_battery() 的方法。這個方法檢查電瓶容量,如果它不是85,就將它 設定為85。建立一輛電瓶容量為預設值的電動汽車,呼叫方法get_range() ,然後對電瓶進行升級,並再次呼叫get_range() 。你會看到這輛汽車的續航里程增 加了。

要點,熟練運用繼承方法,運用例項作為屬性的方法。

class Restaurant():
    def __init__(self, restaurant_name, cuisine_type):
        self.restaurant_name = restaurant_name
        self.cuisine_type = cuisine_type
        self.number_served = 0

    def describe_restaurant(self):
        print(self.restaurant_name,':' ,self.cuisine_type)
    def open_retaurant(self):
        print('It opening')
    def set_number_served(self, number): # 方法設定就餐人數。
        self.number_served = number
    def increment_number_served(self,number): # 執行條件判斷,進行數值遞增。
        while self.number_served < number:
            print(self.number_served)
            self.number_served += 1


restaurant = Restaurant('A', 'B')
restaurant.describe_restaurant()
restaurant.open_retaurant()
restaurant.set_number_served(10)
restaurant.increment_number_served(12) # 座位數量上限。

class IceCreamStand(Restaurant): # 子類(父類)
    def __init__(self, restaurant_name, cuisine_type):
        super().__init__(restaurant_name,cuisine_type) # super().父類的屬性。
        self.flavors = ['A', 'B', 'C']
    def show_icecram(self):
        for i in self.flavors:
            print(i)
icecream = IceCreamStand('D', 'E')
icecream.show_icecram()
icecream.describe_restaurant() # 直接呼叫

# *****************************************

class User():    # 此練習鞏固對類的理解。
    def __init__(self, first_name, last_name):
        self.first_name = first_name
        self.last_name = last_name
        self.login_attempts = 0
    def describe_user(self):
        print(self.first_name, self.last_name)
    def greet_user(self):
        print('Welcome')
    def increment_login_attempts(self):
        self.login_attempts += 1
    def reset_login_attempts(self):
            re = self.login_attempts = 0
            print(re)

user = User('A','B')
user.describe_user()
user.greet_user()
for i in range(7):
    user.increment_login_attempts()
    print(user.login_attempts)
user.reset_login_attempts()

class Privileges():
    def __init__(self):
        self.privileges = ['can add post', 'can delete post', 'can ban user']

    def show_privileges(self):
        for i in self.privileges:
            print(i)


class Admin(User):
    def __init__(self,first_name, last_name):
        super().__init__(first_name, last_name)
        self.privileges = Privileges() # 例項Privileges作為Admin的屬性。

    def show_privileges1(self):
        self.privileges.show_privileges() # 這裡show_p1呼叫了Admin的show_p
                                         # 多個類時運用減少工作量

admin = Admin('A','B')
admin.show_privileges1()

# *****************************************

class Car():  # 書中例子,直接看class Battery 和 class EletriCar 理解例項作為屬性呼叫即可。

    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

    def read_odometer(self):
        print("This car has " + str(self.odometer_reading) + " miles on it.")

    def update_odometer(self, milegeage):
        if milegeage >= self.odometer_reading:
            self.odometer_reading = milegeage
        else:
            print("You can't roll back an odometer!")

    def increment_odometer(self, miles):
        self.odometer_reading += miles

class Battery():

    def __init__(self, battery_size=70):
        self.battery_size = battery_size # 定義的函式屬性。

    def describe_battery(self):
        print("This car has a " + str(self.battery_size) + "-kWh battery")

    def upgrade_battery(self):
        if self.battery_size != 85:
            self.battery_size = 85

    def get_range(self):
        if self.battery_size == 70:
            range = 240
        elif self.battery_size == 85:
            range = 270
        message = "This car can go approximately " + str(range)
        message += "miles on a full charge."
        print(message)
        self.upgrade_battery()

class ElectricCar(Car): # 直接呼叫或繼承上面類和方法,減少工作量。

    def __init__(self, make, model, year):
        super().__init__(make, model, year)
        self.battery_size = Battery()

    def describe_battery(self):
        self.battery_size.battery_size()

    def get_range(self):
        self.battery_size.get_range() # Battery的例項定義為EletriCar的屬性。
        
my_tesla = ElectricCar('tesla', 'model s', 2016)
my_tesla.get_range()
my_tesla.get_range()