《python编程从入门到实践》第2版 第九章课后练习

2023-12-03 03:15

本文主要是介绍《python编程从入门到实践》第2版 第九章课后练习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第九章

  • 练习9-1
  • 练习9-2
  • 练习9-3
  • 练习9-4
  • 练习9-5
  • 练习9-6
  • 练习9-7
  • 练习9-8
  • 练习9-9
  • 练习9-10
  • 练习9-11
  • 练习9-12
  • 练习9-13
  • 练习9-14
  • 练习9-15
  • 练习9-16

练习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_nameself.cuisine_type = cuisine_typedef describe_restaurant(self):print(self.restaurant_name.upper() + "---"+self.cuisine_type.title())def open_restaurant(self):print(self.restaurant_name.upper()+" is now opening!")my_restaurant = Restaurant('kfc', 'hamburg')
my_restaurant.describe_restaurant()
my_restaurant.open_restaurant()

输出:

KFC---Hamburg
KFC is now opening!

练习9-2

三家餐馆 根据为完成练习9-1而编写的类创建三个实例,并对每个实例调用方法describe_restaurant() 。

class Restaurant:def __init__(self, restaurant_name, cuisine_type):self.restaurant_name = restaurant_nameself.cuisine_type = cuisine_typedef describe_restaurant(self):print(self.restaurant_name.upper() + "---"+self.cuisine_type.title())def open_restaurant(self):print(self.restaurant_name.upper()+" is now opening!")my_restaurant1 = Restaurant('kfc', 'hamburg')
my_restaurant1.describe_restaurant()my_restaurant2 = Restaurant('cnhls', 'fried chicken')
my_restaurant2.describe_restaurant()my_restaurant3 = Restaurant('mcd', 'cola')
my_restaurant3.describe_restaurant()

输出:

KFC---Hamburg
CNHLS---Fried Chicken
MCD---Cola

练习9-3

用户 创建一个名为User 的类,其中包含属性first_name 和last_name ,以及用户简介通常会存储的其他几个属性。在类User中定义一个名为describe_user() 的方法,用于打印用户信息摘要。再定义一个名为greet_user() 的方法,用于向用户发出个性化的问候。

创建多个表示不同用户的实例,并对每个实例调用上述两个方法。

class User:def __init__(self, first_name, last_name, age):self.first_name = first_name.title()self.last_name = last_name.title()self.age = agedef describe_user(self):print(f"\n{self.first_name} {self.last_name} {self.age}")  def greet_user(self):print(f"\nWelcome back, {self.first_name} {self.last_name} !")user = User('zhang','san',age='21')
user.describe_user()
user.greet_user()

输出:

Zhang San 21Welcome back, Zhang San !

练习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_nameself.cuisine_type = cuisine_typeself.number_served = 0def describe_restaurant(self):print(self.restaurant_name.upper() + "---"+self.cuisine_type.title())def open_restaurant(self):print(self.restaurant_name.upper()+" is now opening!")def set_number_served(self, number):self.number_served = numberdef increment_number_served(self, increment_number):self.number_served += increment_numbermy_restaurant = Restaurant('kfc', 'hamburg')
print(f"\n初始人数: {my_restaurant.number_served}")
my_restaurant.set_number_served(10)
print(f"\n修改后的人数: {my_restaurant.number_served}")
my_restaurant.increment_number_served(100)
print(f"\n增加后的人数: {my_restaurant.number_served}")

输出:

初始人数: 0修改后的人数: 10增加后的人数: 110

练习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, age):self.first_name = first_name.title()self.last_name = last_name.title()self.age = ageself.login_attempts = 0def describe_user(self):print(f"\n{self.first_name} {self.last_name} {self.age}")  def greet_user(self):print(f"\nWelcome back, {self.first_name} {self.last_name} !")def increment_login_attempts(self):self.login_attempts += 1def reset_login_attempts(self):self.login_attempts = 0user = User('zhang','san',age='21')
user.describe_user()
user.greet_user()for i in range(5):user.increment_login_attempts()print(user.login_attempts)
user.reset_login_attempts()
print(user.login_attempts)

输出:

Zhang San 21Welcome back, Zhang San !
1
2
3
4
5
0

练习9-6

冰激凌小店 冰激凌小店是一种特殊的餐馆。编写一个名为IceCreamStand 的类,让它继承为完成练习9-1或练习9-4而编写的Restaurant 类。这两个版本的Restaurant 类
都可以,挑选你更喜欢的那个即可。添加一个名为flavors 的属性,用于存储一个由各种口味的冰激凌组成的列表。编写一个显示这些冰激凌的方法。创建一个IceCreamStand 实例,
并调用这个方法。

class Restaurant:def __init__(self, restaurant_name, cuisine_type):self.restaurant_name = restaurant_nameself.cuisine_type = cuisine_typeself.number_served = 0def describe_restaurant(self):print(self.restaurant_name.upper() + "---"+self.cuisine_type.title())def open_restaurant(self):print(self.restaurant_name.upper()+" is now opening!")def set_number_served(self, number):self.number_served = numberdef increment_number_served(self, increment_number):self.number_served += increment_numberclass IceCreamStand(Restaurant):def __init__(self, restaurant_name, cuisine_type):super().__init__(restaurant_name, cuisine_type)self.flavors = ['strawberry', 'youthful', 'tomato']def show_flavors(self):print("口味如下:")for flavor in self.flavors:print(flavor)my_icecreamstand = IceCreamStand('kfc', 'ice cream')
my_icecreamstand.describe_restaurant()
my_icecreamstand.open_restaurant()
my_icecreamstand.show_flavors()

输出:

KFC---Ice Cream
KFC is now opening!
口味如下:
strawberry
youthful
tomato

练习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, age):self.first_name = first_name.title()self.last_name = last_name.title()self.age = ageself.login_attempts = 0def describe_user(self):print(f"\n{self.first_name} {self.last_name} {self.age}")  def greet_user(self):print(f"\nWelcome back, {self.first_name} {self.last_name} !")def increment_login_attempts(self):self.login_attempts += 1def reset_login_attempts(self):self.login_attempts = 0class Admin(User):def __init__(self, first_name, last_name, age):super().__init__(first_name, last_name, age)self.privileges = ["can add post", "can delete post", "can ban user"]def show_privileges(self):print("The administrator's permissions are as follows: ")for privilege in self.privileges:print("-- "+privilege)admin = Admin('zhang','san',age='21')admin.describe_user()
admin.show_privileges()

输出:

Zhang San 21
The administrator's permissions are as follows: 
-- can add post
-- can delete post
-- can ban user

练习9-8

权限 编写一个名为 Privileges 的类,它只有一个属性 privileges ,其中存储了练习9-7所述的字符串列表。将方法 show_privileges() 移到这个类中。在 Admin 类中,将一个 Privileges 实例用作其属性。创建一个 Admin 实例,并使用方法 show_privileges() 来显示其权限。

class User:def __init__(self, first_name, last_name, age):self.first_name = first_name.title()self.last_name = last_name.title()self.age = ageself.login_attempts = 0def describe_user(self):print(f"\n{self.first_name} {self.last_name} {self.age}")  def greet_user(self):print(f"\nWelcome back, {self.first_name} {self.last_name} !")def increment_login_attempts(self):self.login_attempts += 1def reset_login_attempts(self):self.login_attempts = 0class Privileges():def __init__(self):self.privileges = ["can add post", "can delete post", "can ban user"]def show_privileges(self):print("The administrator's permissions are as follows: ")for privilege in self.privileges:print("-- "+privilege)class Admin(User):def __init__(self, first_name, last_name, age):super().__init__(first_name, last_name, age)self.privileges = Privileges()admin = Admin('zhang','san',age='21')admin.describe_user()
admin.privileges.show_privileges()

输出:

Zhang San 21
The administrator's permissions are as follows: 
-- can add post
-- can delete post
-- can ban user

练习9-9

电瓶升级 在本节最后一个electric_car.py版本中,给 Battery 类添加一个名为upgrade_battery() 的方法。该方法检查电瓶容量,如果不是100,就将其设置为100。创建一
辆电瓶容量为默认值的电动汽车,调用方法get_range() ,然后对电瓶进行升级,并再次调用get_range() 。你将看到这辆汽车的续航里程增加了。

class Car:def __init__(self, make, model, year):self.make = makeself.model = modelself.year = yearself.odometer_reading = 0def get_describe_name(self):return str(self.year) + " " + self.make + ' ' + self.modeldef read_odometer(self):print("This car has " + str(self.odometer_reading) + " mils on it")def updte_odometer(self,mileage):if mileage >= self.odometer_reading:self.odometer_reading = mileageelse:print("You can't roll back an odmeter!")def increment_odometer(self,miles):self.odometer_reading += milesclass Battery:def __init__(self, battery_size=70):self.battery_size = battery_sizedef describe_battery(self):print("This car has a " + str(self.battery_size) + "-kwh battery. ")def get_range(self):if self.battery_size == 70:range = 240elif self.battery_size == 85:range = 270print("This car can go approximately "+str(range)+".")def upgrade_battery(self):if self.battery_size != 100:self.battery_size = 100print(self.battery_size)class ElectricCar(Car):def __init__(self, make, model, year):super(ElectricCar, self).__init__(make, model, year)self.battery = Battery()ele_car=ElectricCar('tesla','model',2016)
ele_car.battery.get_range()
ele_car.battery.upgrade_battery()

输出:

This car can go approximately 240.
100

练习9-10

导入Restaurant 类 将最新的Restaurant 类存储在一个模块中。在另一个文件中,导入Restaurant 类,创建一个Restaurant 实例并调用Restaurant 的一个方法,以确认import 语句正确无误。

from restaurant import Restaurant

练习9-11

导入Admin 类 以为完成练习9-8而做的工作为基础。将User 类、Privileges 类和Admin 类存储在一个模块中,再创建一个文件,在其中创建一个Admin 实例并对其调用方法show_privileges() ,以确认一切都能正确运行。

from admin import Adminuser = Admin('harden', 'james', 30)
user.privileges.show_privileges()

练习9-12

多个模块 将User 类存储在一个模块中,并将Privileges 类和Admin 类存储在另一个模块中。再创建一个文件,在其中创建一个Admin 实例并对其调用方法show_privileges() ,以确认一切依然能够正确运行。

from user import Userfrom admin import Adminuser = Admin('harden', 'james', 30)

练习9-13

骰子 创建一个Die 类,它包含一个名为sides 的属性,该属性的默认值为6。编写一个名为roll_die() 的方法,它打印位于1和骰子面数之间的随机数。创建一个6面的骰子再掷10次。

创建一个10面的骰子和一个20面的骰子,再分别掷10次。

from random import randintclass Die:def __init__(self, sides=6):self.sides = sidesdef roll_die(self):print(randint(1, self.sides))print("======6======")
die = Die()
for i in range(1, 11):die.roll_die()print("======10======")
die = Die(10)
for i in range(1, 11):die.roll_die()print("======20======")
die = Die(20)
for i in range(1, 11):die.roll_die()

输出:

======6======
1
3
3
3
5
4
5
2
2
4
======10======
3
4
4
4
3
7
7
1
6
6
======20======
3
12
16
10
15
11
3
6
19
9

练习9-14

彩票 创建一个列表或元组,其中包含10个数和5个字母。从这个列表或元组中随机选择4个数或字母,并打印一条消息,指出只要彩票上是这4个数或字母,就中大奖了。

from random import choicepossibilities = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 'a', 'b', 'c', 'd', 'e']
winning_ticket = []
print("开始选择...")while len(winning_ticket) < 4:pulled_item = choice(possibilities)if pulled_item not in winning_ticket:print(f"你选择了{pulled_item}!")winning_ticket.append(pulled_item)print("\n你的彩票是:")
for i in winning_ticket:print(i, end=" ")
print("\n恭喜你中奖!")

输出:

开始选择...
你选择了c!
你选择了e!
你选择了a!
你选择了d!你的彩票是:
c e a d 
恭喜你中奖!

练习9-15

彩票分析 可以使用一个循环来明白前述彩票大奖有多难中奖。为此,创建一个名为my_ticket 的列表或元组,再编写一个循环,不断地随机选择数或字母,直到中大奖为止。请打印一条消息,报告执行循环多少次才中了大奖。

from random import choicedef get_winning_ticket(possibilities):winning_ticket = []while len(winning_ticket) < 4:pulled_item = choice(possibilities)if pulled_item not in winning_ticket:winning_ticket.append(pulled_item)return winning_ticketdef check_ticket(win_tickets, tickets):n = 0my_tickets = []while True:i = 0 copy_tickets = tickets[:]while i < len(win_tickets):n += 1chioce = choice(copy_tickets)my_tickets.append(chioce)copy_tickets.remove(chioce)i += 1if my_tickets != win_tickets:while my_tickets:my_tickets.pop()continueelse:print(f'您抽的号码为:\n{my_tickets}')print('\n恭喜您中奖了!')    print(f'您抽奖抽了{n}次!')breaknumbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 'a', 'b', 'c', 'd', 'e']
win = get_winning_ticket(numbers) 
print(f'本期开奖号码:\n{win}')
check_ticket(win, numbers)

输出:

本期开奖号码:
['d', 'e', 7, 'c']
您抽的号码为:
['d', 'e', 7, 'c']恭喜您中奖了!
您抽奖抽了13360次!

练习9-16

Python Module of the Week 要了解Python标准库,一个很不错的资源是网站Python Module of the Week。请访问该网站并查看其中的目录,找一个你感兴趣的模块进行探索。从模块random 开始可能是个不错的选择。

这篇关于《python编程从入门到实践》第2版 第九章课后练习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/447878

相关文章

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B