1. 程式人生 > >Python程式設計從入門到實踐課後答案:第九章

Python程式設計從入門到實踐課後答案:第九章

9-1 餐館 :建立一個名為Restaurant 的類,其方法__init__() 設定兩個屬性:restaurant_name 和cuisine_type 。建立一個名
為describe_restaurant() 的方法和一個名為open_restaurant() 的方法,其中前者列印前述兩項資訊,而後者列印一條訊息,指出餐館正在營業。
根據這個類建立一個名為restaurant 的例項,分別列印其兩個屬性,再呼叫前述兩個方法。
9-2 三家餐館 :根據你為完成練習9-1而編寫的類建立三個例項,並對每個例項呼叫方法describe_restaurant() 。
9-3 使用者 :建立一個名為User 的類,其中包含屬性first_name 和last_name ,還有使用者簡介通常會儲存的其他幾個屬性。在類User 中定義一個名
為describe_user() 的方法,它列印使用者資訊摘要;再定義一個名為greet_user() 的方法,它向用戶發出個性化的問候。
建立多個表示不同使用者的例項,並對每個例項都呼叫上述兩個方法。

# 9-1
class Restaurant:
    def __init__(self, restaurant_name, cuisine_type):
        self.restaurant_name = restaurant_name
        self.cuisine_type = cuisine_type

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

    def open_restaurant(self):
        print("餐館正在營業")


r = Restaurant("A", "B")
r.describe_restaurant()
r.open_restaurant()
# 9-2
class Restaurant:
    def __init__(self, restaurant_name, cuisine_type):
        self.restaurant_name = restaurant_name
        self.cuisine_type = cuisine_type

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

    def open_restaurant(self):
        print("餐館正在營業")
r = Restaurant("A", "B")
r.describe_restaurant()

r1 = Restaurant("A", "B")
r1.describe_restaurant()

r2 = Restaurant("A", "B")
r2.describe_restaurant()
# 9-3
class User:
    def __init__(self, first_name, last_name):
        self.first_name = first_name
        self.last_name = last_name

    def describe_user(self):
        print("該使用者名稱字是%s %s" % (self.first_name, self.last_name))

    def greet_user(self):
        print("hello world")


u = User("鄭", "超")
u.describe_user()
u.greet_user()

9-4 就餐人數 :在為完成練習9-1而編寫的程式中,新增一個名為number_served 的屬性,並將其預設值設定為0。根據這個類建立一個名為restaurant 的實
例;列印有多少人在這家餐館就餐過,然後修改這個值並再次列印它。
新增一個名為set_number_served() 的方法,它讓你能夠設定就餐人數。呼叫這個方法並向它傳遞一個值,然後再次列印這個值。
新增一個名為increment_number_served() 的方法,它讓你能夠將就餐人數遞增。呼叫這個方法並向它傳遞一個這樣的值:你認為這家餐館每天可能接待的就
餐人數。
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。

# 9-4
class Restaurant:
    def __init__(self, restaurant_name, cuisine_type, number_served=0):
        self.restaurant_name = restaurant_name
        self.cuisine_type = cuisine_type
        self.number_served = number_served

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

    def open_restaurant(self):
        print("餐館正在營業,共有%d人在該餐館進食" % self.number_served)


restaurant = Restaurant("A", "B")
restaurant.describe_restaurant()
restaurant.open_restaurant()

restaurant1 = Restaurant("A", "B",number_served=10)
restaurant1.describe_restaurant()
restaurant1.open_restaurant()

# 9-5
class User:
    def __init__(self, first_name, last_name, login_attempts):
        self.first_name = first_name
        self.last_name = last_name
        self.login_attempts = login_attempts

    def describe_user(self):
        print("該使用者名稱字是%s %s" % (self.first_name, self.last_name))

    def greet_user(self):
        print("hello world")

    def increment_login_attempts(self):
        self.login_attempts += 1
        return self.login_attempts

    def reset_login_attempts(self):
        self.login_attempts = 0
        return self.login_attempts


u = User("鄭", "超", 1)
print(u.increment_login_attempts())
print(u.increment_login_attempts())
print(u.increment_login_attempts())
print(u.reset_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("%s:%s" % (self.restaurant_name, self.cuisine_type))

    def open_restaurant(self):
        print("餐館正在營業")


class IceCreamStand(Restaurant):
    def __init__(self, restaurant_name, cuisine_type):
        super().__init__(restaurant_name, cuisine_type)
        self.flavors = ['A', 'B', 'O']

    def show_ice_cream(self):
        for i in self.flavors:
            print(i)


ice = IceCreamStand("a", "b")
ice.show_ice_cream()
ice.describe_restaurant()

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

# 9-7
class User:
    def __init__(self, first_name, last_name):
        self.first_name = first_name
        self.last_name = last_name

    def describe_user(self):
        print("該使用者名稱字是%s %s" % (self.first_name, self.last_name))

    def greet_user(self):
        print("hello world")


class Admin(User):
    def __init__(self, first_name, last_name):
        super().__init__(first_name, last_name)
        self.privileges = ["can add post", "can delete post", "can ban user"]

    def show_privileges(self):
        for i in self.privileges:
            print("you %s" % i)


admin = Admin("鄭", "超")
admin.describe_user()
admin.greet_user()
admin.show_privileges()

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

# 9-8
class User:
    def __init__(self, first_name, last_name):
        self.first_name = first_name
        self.last_name = last_name

    def describe_user(self):
        print("該使用者名稱字是%s %s" % (self.first_name, self.last_name))

    def greet_user(self):
        print("hello world")


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, first_name, last_name):
        super().__init__(first_name, last_name)
        self.privileges = Privileges()

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


admin = Admin("鄭", "超")
admin.describe_user()
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

    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_kilometre(self):
        if self.battery_size == 70:
            kilometre = 240
        elif self.battery_size == 85:
            kilometre = 270
        message = "This car can go approximately " + str(kilometre)
        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_kilometre(self):
        self.battery_size.get_kilometre()


e = ElectricCar('tesla', 'model s', 2016)
e.get_kilometre()
e.get_kilometre()

9-14 骰子 :模組random 包含以各種方式生成隨機數的函式,其中的randint() 返回一個位於指定範圍內的整數,例如,下面的程式碼返回一個1~6內的整數:
from random import randint
x = randint(1, 6)
請建立一個Die 類,它包含一個名為sides 的屬性,該屬性的預設值為6。編寫一個名為roll_die() 的方法,它列印位於1和骰子面數之間的隨機數。建立一個6面
的骰子,再擲10次。 建立一個10面的骰子和一個20面的骰子,並將它們都擲10次。

from random import randint


class Die:
    def __init__(self, sides=6):
        self.sides = sides

    def roll_die(self):
        x = randint(1, 6)
        self.sides = x
        print(self.sides)

    def roll_die1(self):
        x = randint(1, 10)
        self.sides = x
        print(self.sides)

    def roll_die2(self):
        self.sides = randint(1, 20)
        print(self.sides)


d = Die()
print(d.sides)
for i in range(10):
    d.roll_die()
print("*" * 30)
for i in range(10):
    d.roll_die1()
print("*" * 30)
for i in range(10):
    d.roll_die2()