1. 程式人生 > >【Python程式設計:從入門到實踐】第九章:類

【Python程式設計:從入門到實踐】第九章:類

9-1 餐館 :建立一個名為Restaurant 的類,其方法__init__() 設定兩個屬性:restaurant_name 和cuisine_type 。建立一個名 為describe_restaurant() 的方法和一個名為open_restaurant() 的方法,其中前者列印前述兩項資訊,而後者列印一條訊息,指出餐館正在營業。

class  Restraurant():
	"""docstring for  Restraurant"""
	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,":",self.cuisine_type)
	def open_restaurant(self):
		print("Is opening")

restraurant = Restraurant('A','B')
print(restraurant.restaurant_name," ",restraurant.cuisine_type)
restraurant.describe_restaurant()
restraurant.open_restaurant()		
結果:



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

class  Restraurant():
	"""docstring for  Restraurant"""
	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,":",self.cuisine_type)
	def open_restaurant(self):
		print("Is opening")

restraurant1 = Restraurant('A1','B1')
restraurant1.describe_restaurant()
restraurant2 = Restraurant('A2','B2')
restraurant2.describe_restaurant()
restraurant3 = Restraurant('A3','B3')
restraurant3.describe_restaurant()
		
結果:

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

class User():
	"""docstring for User"""
	def __init__(self, first_name,last_name):
		self.first_name = first_name
		self.last_name = last_name

	def describe_name(self):
		print("fitst_name :",self.first_name," last_name: ",self.last_name)

	def greet_user(self):
		print("hello, ",self.first_name," ",self.last_name)

user1 = User('Alice','Tom')
user1.describe_name()
user1.greet_user()
user2 = User("Mary",'Bob')
user2.describe_name()
user2.greet_user()
user3 = User("Tony",'Belbert')
user3.describe_name()
user3.greet_user()
結果:



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

新增一個名為set_number_served() 的方法,它讓你能夠設定就餐人數。呼叫這個方法並向它傳遞一個值,然後再次列印這個值。

新增一個名為increment_number_served() 的方法,它讓你能夠將就餐人數遞增。呼叫這個方法並向它傳遞一個這樣的值:你認為這家餐館每天可能接待的就 餐人數。

class  Restraurant():
	"""docstring for  Restraurant"""
	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_restaurant(self):
		print("Is opening")
	def set_number_served(self,number):
		self.number_served = number
	def get_number_served(self):
		return self.number_served
	def increment_number_served(self,number):
		while self.number_served < number:
			print(self.number_served)
			self.number_served +=1

restraurant = Restraurant('A','B')
print(restraurant.restaurant_name," ",restraurant.cuisine_type)
restraurant.describe_restaurant()
restraurant.open_restaurant()
print(restraurant.get_number_served())
restraurant.set_number_served(2)
print(restraurant.get_number_served())
restraurant.increment_number_served(10)
結果:



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():
	"""docstring for User"""
	def __init__(self, first_name,last_name):
		self.first_name = first_name
		self.last_name = last_name
		self.login_attempts = 0

	def describe_name(self):
		print("fitst_name :",self.first_name," last_name: ",self.last_name)

	def greet_user(self):
		print("hello, ",self.first_name," ",self.last_name)

	def  increment_login_attempts(self):
		self.login_attempts += 1
	def reset_login_attempts(self):
		self.login_attempts = 0

user1 = User('Alice','Tom')
user1.describe_name()
print("login_attempts:",user1.login_attempts)
user1.increment_login_attempts()
print("login_attempts:",user1.login_attempts)
user1.increment_login_attempts()
print("login_attempts:",user1.login_attempts)
user1.reset_login_attempts()
print("login_attempts:",user1.login_attempts)
結果:



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

class  Restraurant():
	"""docstring for  Restraurant"""
	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_restaurant(self):
		print("Is opening")
	def set_number_served(self,number):
		self.number_served = number
	def get_number_served(self):
		return self.number_served
	def increment_number_served(self,number):
		while self.number_served < number:
			print(self.number_served)
			self.number_served +=1

class IceCreamStand(Restraurant):
	def __init__(self, restaurant_name,cuisine_type):
		super().__init__(restaurant_name,cuisine_type)
		self.flavors = ['banaa','apple','orange']
	def show_icecram(self):
		for s in self.flavors:
			print(s)

icecream = IceCreamStand('Hang','Big')
icecream.show_icecram()
icecream.describe_restaurant()

結果:



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

class User():
	"""docstring for User"""
	def __init__(self, first_name,last_name):
		self.first_name = first_name
		self.last_name = last_name
		self.login_attempts = 0

	def describe_name(self):
		print("fitst_name :",self.first_name," last_name: ",self.last_name)

	def greet_user(self):
		print("hello, ",self.first_name," ",self.last_name)

	def  increment_login_attempts(self):
		self.login_attempts += 1
	def reset_login_attempts(self):
		self.login_attempts = 0

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

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

admin = Admin("Alice",'Bob')
admin.show_privileges()
		
結果:



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

class User():
	"""docstring for User"""
	def __init__(self, first_name,last_name):
		self.first_name = first_name
		self.last_name = last_name
		self.login_attempts = 0

	def describe_name(self):
		print("fitst_name :",self.first_name," last_name: ",self.last_name)

	def greet_user(self):
		print("hello, ",self.first_name," ",self.last_name)

	def  increment_login_attempts(self):
		self.login_attempts += 1
	def reset_login_attempts(self):
		self.login_attempts = 0
class Privileges():
	"""docstring for Privileges"""
	def __init__(self):
		self.privileges = ['can add post','can ban user','can delete post']
	def show_privileges(self):
		print(self.privileges)
class Admin(User):
	"""docstring for Admin"""
	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("Alice",'Bob')
admin.show_privileges()
		
結果:

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

class Car():
	"""docstring for 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():
	"""docstring for 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):
	"""docstring for ElectricCar"""
	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()

my_tesla = ElectricCar('tesla','model s',2016)
my_tesla.get_range()
my_tesla.get_range()
結果:

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

restaurant.py

class  Restraurant():
	"""docstring for  Restraurant"""
	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_restaurant(self):
		print("Is opening")
	def set_number_served(self,number):
		self.number_served = number
	def get_number_served(self):
		return self.number_served
	def increment_number_served(self,number):
		while self.number_served < number:
			print(self.number_served)
			self.number_served +=1
coding.py
from restraurant import Restraurant
restraurant1 = Restraurant('A','B')
print(restraurant1.restaurant_name," ",restraurant1.cuisine_type)
restraurant1.describe_restaurant()
restraurant1.open_restaurant()
print(restraurant1.get_number_served())
restraurant1.set_number_served(2)
print(restraurant1.get_number_served())
restraurant1.increment_number_served(10)
結果:



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

user.py

class User():
	"""docstring for User"""
	def __init__(self, first_name,last_name):
		self.first_name = first_name
		self.last_name = last_name
		self.login_attempts = 0

	def describe_name(self):
		print("fitst_name :",self.first_name," last_name: ",self.last_name)

	def greet_user(self):
		print("hello, ",self.first_name," ",self.last_name)

	def  increment_login_attempts(self):
		self.login_attempts += 1
	def reset_login_attempts(self):
		self.login_attempts = 0
class Privileges():
	"""docstring for Privileges"""
	def __init__(self):
		self.privileges = ['can add post','can ban user','can delete post']
	def show_privileges(self):
		print(self.privileges)
class Admin(User):
	"""docstring for Admin"""
	def __init__(self, first_name,last_name):
		super().__init__(first_name,last_name)
		self.privileges = Privileges()

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

coding.py

from user import Admin
admin = Admin("Alice",'Bob')
admin.show_privileges()
結果:



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

privileges.py

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

admin.py

class Admin(User):
	"""docstring for Admin"""
	def __init__(self, first_name,last_name):
		super().__init__(first_name,last_name)
		self.privileges = Privileges()

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

user.py

class User():
	"""docstring for User"""
	def __init__(self, first_name,last_name):
		self.first_name = first_name
		self.last_name = last_name
		self.login_attempts = 0

	def describe_name(self):
		print("fitst_name :",self.first_name," last_name: ",self.last_name)

	def greet_user(self):
		print("hello, ",self.first_name," ",self.last_name)

	def  increment_login_attempts(self):
		self.login_attempts += 1
	def reset_login_attempts(self):
		self.login_attempts = 0
coding.py
from user import User
from admin import Admin
from privilege import Privilege
admin = Admin("Alice",'Bob')
admin.show_privileges()
結果:


9-13 使用OrderedDict :在練習6-4中,你使用了一個標準字典來表示詞彙表。請使用OrderedDict 類來重寫這個程式,並確認輸出的順序與你在字典中新增鍵 —值對的順序一致。 

from collections import OrderedDict
favorite_languages = OrderedDict()
favorite_languages['jen'] = 'python'
favorite_languages['sarah'] = 'c'
favorite_languages['edward'] = 'ruby'
favorite_languages['phil'] = 'python'
for key,value in favorite_languages.items():
	print(key.title() + " 's favorite languages is "+value.title() + ".")
結果:



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():
	"""docstring for Die"""
	def __init__(self):
		self.sides = 6
	def roll_die(self):
		x = randint(1,6)
		self.sides=x
		print(self.sides)
	def roll_die10(self):
		x = randint(1,10)
		self.sides = x
		print(self.sides)
	def  roll_die20(self):
		self.sides = randint(1,20)
		print(self.sides)
die = Die()
print(die.sides)
print("6 sides")
for i in range(0,10):
	die.roll_die()
print("10 sides")
for i in range(0,10):
	die.roll_die10()
print("20 sides")
for i in range(0,10):
	die.roll_die20()
		
結果: