1. 程式人生 > >《Python程式設計:從入門到實踐》第9章 類

《Python程式設計:從入門到實踐》第9章 類

第9章 類

9-1 餐館

建立一個名為Restaurant 的類,其方法__init__() 設定兩個屬性:restaurant_name 和cuisine_type 。建立一個名為describe_restaurant() 的方法和一個名為open_restaurant() 的方法,其中前者列印前述兩項資訊,而後者列印一條訊息,指出餐館正在營業。 根據這個類建立一個名為restaurant 的例項,分別列印其兩個屬性,再呼叫前述兩個方法。

class Restaurant():

    def __init__(self, restaurant_name, cuisine_type):
self.restaurant_name = restaurant_name self.cuisine_type = cuisine_type def describe_restaurant(self): print(self.restaurant_name.title(), " ", self.cuisine_type.title()) def open_restaurant(self): print("Restaurant is open.") restaurant = Restaurant('delicious restaurant'
, 'fast food') print(restaurant.restaurant_name.title(), " ", restaurant.cuisine_type.title()) restaurant.describe_restaurant() restaurant.open_restaurant()

9-2 三家餐館

根據你為完成練習9-1而編寫的類建立三個例項,並對每個例項呼叫方法describe_restaurant() 。

class Restaurant():

    def __init__(self, restaurant_name, cuisine_type)
: self.restaurant_name = restaurant_name self.cuisine_type = cuisine_type def describe_restaurant(self): print(self.restaurant_name.title(), " ", self.cuisine_type.title()) def open_restaurant(self): print("Restaurant is open.") restaurnat1 = Restaurant('a1', 'b1') restaurnat1.describe_restaurant() restaurnat2 = Restaurant('a2', 'b2') restaurnat2.describe_restaurant() restaurnat3 = Restaurant('a3', 'b3') restaurnat3.describe_restaurant()

9-3 使用者

建立一個名為User 的類,其中包含屬性first_name 和last_name ,還有使用者簡介通常會儲存的其他幾個屬性。在類User 中定義一個名為describe_user() 的方法,它列印使用者資訊摘要;再定義一個名為greet_user() 的方法,它向用戶發出個性化的問候。 建立多個表示不同使用者的例項,並對每個例項都呼叫上述兩個方法。

class User():

    def __init__(self, first_name, last_name):
        self.first_name = first_name
        self.last_name = last_name

    def describe_user(self):
        print("Name: " + self.first_name.title() +
              " " + self.last_name.title())

    def greet_user(self):
        print("Hello, " + self.first_name.title() +
              " " + self.last_name.title())


name1 = User('clark', 'pan')
name1.describe_user()
name1.greet_user()
name2 = User('jack', 'tony')
name2.describe_user()
name2.greet_user()

9-4 就餐人數

在為完成練習9-1而編寫的程式中,新增一個名為number_served 的屬性,並將其預設值設定為0。根據這個類建立一個名為restaurant 的例項;列印有多少人在這家餐館就餐過,然後修改這個值並再次列印它。

  • 新增一個名為set_number_served() 的方法,它讓你能夠設定就餐人數。呼叫這個方法並向它傳遞一個值,然後再次列印這個值。
  • 新增一個名為increment_number_served() 的方法,它讓你能夠將就餐人數遞增。呼叫這個方法並向它傳遞一個這樣的值:你認為這家餐館每天可能接待的就餐人數。
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.title(), " ", self.cuisine_type.title())

    def open_restaurant(self):
        print("Restaurant is open.")

    def set_number_served(self, number):
        self.number_served = number
        print(self.number_served)

    def increment_number_served(self, number):
        while self.number_served <= number:
            print(self.number_served)
            self.number_served += 1


restaurant = Restaurant('delicious restaurant', 'fast food')
print(restaurant.restaurant_name.title(), " ", restaurant.cuisine_type.title())
restaurant.describe_restaurant()
restaurant.open_restaurant()

print(str(restaurant.number_served) + " people have eaten at this restaurant.")
restaurant.number_served = 2
print(str(restaurant.number_served) + " people have eaten at this restaurant.")

restaurant.set_number_served(3)
restaurant.increment_number_served(20)

9-5 嘗試登陸次數

在為完成練習9-3而編寫的User 類中,新增一個名為login_attempts 的屬性。編寫一個名為increment_login_attempts() 的方法,它將屬性login_attempts 的值加1。再編寫一個名為reset_login_attempts() 的方法,它將屬性login_attempts 的值重置為0。 根據User 類建立一個例項,再呼叫方法increment_login_attempts() 多次。列印屬性login_attempts 的值,確認它被正確地遞增;然後,呼叫方法reset_login_attempts() ,並再次列印屬性login_attempts 的值,確認它被重置為0。

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("Name: " + self.first_name.title() +
              " " + self.last_name.title())

    def greet_user(self):
        print("Hello, " + self.first_name.title() +
              " " + self.last_name.title())

    def increment_login_attempets(self):
        self.login_attempts += 1

    def rest_login_attempts(self):
        self.login_attempts = 0


login = User('clark', 'pan')
login.increment_login_attempets()
login.increment_login_attempets()
print(login.login_attempts)
login.rest_login_attempts()
print(login.login_attempts)

9-6 冰淇淋小店

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

class Restaurant():

    def __init__(self, restaurant_name, cuisine_type):
        self.restaurant_name = restaurant_name
        self.cuisine_type = cuisine_type

    def describe_restaurant(self):
        print(self.restaurant_name.title(), " ", self.cuisine_type.title())

    def open_restaurant(self):
        print("Restaurant is open.")


class IceCreamStand(Restaurant):

    def __init__(self):
        self.flavors = ['Strawbeyy ice cream',
                        'Vanilla ice cream', 'Milk ice cream']

    def ice_display(self):
        print(self.flavors)


ice = IceCreamStand()
ice.ice_display()

9-7 管理員

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

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("Name: " + self.first_name.title() +
              " " + self.last_name.title())

    def greet_user(self):
        print("Hello, " + self.first_name.title() +
              " " + self.last_name.title())

    def increment_login_attempets(self):
        self.login_attempts += 1

    def rest_login_attempts(self):
        self.login_attempts = 0


class Admin(User):

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

    def show_prvileges(self):
        for show in self.privileges:
            print(show.title())


admin = Admin()
admin.show_prvileges()

9-8 許可權

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

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("Name: " + self.first_name.title() +
              " " + self.last_name.title())

    def greet_user(self):
        print("Hello, " + self.first_name.title() +
              " " + self.last_name.title())

    def increment_login_attempets(self):
        self.login_attempts += 1

    def rest_login_attempts(self):
        self.login_attempts = 0


class Privileges():

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

    def show_privileges(self):
        print(self.privileges)


class Admin(User):

    def __init__(self):
        self.privileges = Privileges()

    def show_privileges(self):
        self.privileges.show_privileges()


admin = Admin()
admin.show_privileges()

9-9 電瓶升級

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

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):
        if mileage >= self.odometer_reading:
            self.odometer_reading = mileage
        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)


class ElectricCar(Car):
    """電動汽車的獨特之處"""
    def __init__(self, make, model, year):
        """初始化父類的屬性,再初始化電動汽車特有的屬性"""
        super().__init__(make, model, year)
        self.battery = Battery()

my_tesla = ElectricCar('tesla', 'model s', 2016)
print(my_tesla.get_descriptive_name())
my_tesla.battery.upgrade_battery()
my_tesla.battery.describe_battery()
my_tesla.battery.get_range()

9-10 匯入Restaurant類

將最新的Restaurant 類儲存在一個模組中。在另一個檔案中,匯入Restaurant 類,建立一個Restaurant 例項,並呼叫Restaurant 的一個方法,以確認import 語句正確無誤。

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.title(), " ", self.cuisine_type.title())

    def open_restaurant(self):
        print("Restaurant is open.")

    def set_number_served(self, number):
        self.number_served = number
        print(self.number_served)

    def increment_number_served(self, number):
        while self.number_served <= number:
            print(self.number_served)
            self.number_served += 1

my_restaurant.py

from restaurant import Restaurant

my_restaurant = Restaurant('A', 'B')
my_restaurant.open_restaurant()

9-11 匯入Admin類

以為完成練習9-8而做的工作為基礎,將User 、Privileges 和Admin 類儲存在一個模組中,再建立一個檔案,在其中建立一個Admin 例項並對其呼叫方法show_privileges() ,以確認一切都能正確地執行。

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("Name: " + self.first_name.title() +
              " " + self.last_name.title())

    def greet_user(self):
        print("Hello, " + self.first_name.title() +
              " " + self.last_name.title())

    def increment_login_attempets(self):
        self.login_attempts += 1

    def rest_login_attempts(self):
        self.login_attempts = 0


class Privileges():

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

    def show_privileges(self):
        print(self.privileges)


class Admin(User):

    def __init__(self):
        self.privileges = Privileges()

    def show_privileges(self):
        self.privileges.show_privileges()

my_admin.py

import admin

my_admin = admin.Admin()
my_admin.show_privileges()

9-12 多個模組

將User 類儲存在一個模組中,並將Privileges 和Admin 類儲存在另一個模組中。再建立一個檔案,在其中建立一個Admin 例項,並對其呼叫方法show_privileges() ,以確認一切都依然能夠正確地執行。

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("Name: " + self.first_name.title() +
              " " + self.last_name.title())

    def greet_user(self):
        print("Hello, " + self.first_name.title() +
              " " + self.last_name.title())

    def increment_login_attempets(self):
        self.login_attempts += 1

    def rest_login_attempts(self):
        self