
本文旨在阐明Python中类之间的关联方式,特别是通过实例属性来建立Franchise类和Menu类之间的关系。文章将解释如何在Franchise类中存储Menu类的实例,以及如何通过类型提示和断言来增强代码的可读性和健壮性,同时也会介绍Python的鸭子类型概念。
在Python中,类之间的关联通常通过实例属性来实现。例如,Franchise类通过其menus属性来关联Menu类。 这种关联并非通过显式的“连接”代码来实现,而是通过在Franchise的__init__方法中接收Menu对象的列表,并将这些对象存储在self.menus属性中来建立的。
class Menu: def __init__(self, name, items, start_time, end_time): self.name = name self.items = items self.start_time = start_time self.end_time = end_time def __repr__(self): representative_string = "{name} available from {start_time} to {end_time}" return representative_string.format(name=self.name, start_time=self.start_time, end_time=self.end_time) def calculate_bill(self, purchased_items): total_price = 0 for item in purchased_items: total_price += self.items[item] return total_priceclass Franchise(): def __init__(self, address, menus): self.address = address self.menus = menus def __repr__(self): return f"{self.address}" def available_menus(self, time): available_orders = [] for menu in self.menus: if (time >= menu.start_time and time <= menu.end_time): available_orders.append(menu.name) return available_ordersbrunch = Menu('brunch', {'pancakes': 7.50, 'waffles': 9.00, 'burger': 11.00, 'home fries': 4.50, 'coffee': 1.50, 'espresso': 3.00, 'tea': 1.00, 'mimosa': 10.50, 'orange juice': 3.50}, 11.00, 16.00)early_bird = Menu('early_bird', {'salumeria plate': 8.00, 'salad and breadsticks(serves 2, no refills)': 14.00, 'pizza with quattro formaggi': 9.00, 'duck rugu': 17.50, 'mushroom ravioli (vegan)': 13.50, 'coffee': 1.50, 'espresso': 3.00}, 15.00, 18.00)dinner = Menu('dinner', {'crostini with eggplant caponata': 13.00, 'caesar salad': 16.00, 'pizza with quattro formaggi': 11.00, 'duck ragu': 19.50, 'mushroom ravioli (vegan)': 13.50, 'coffee': 2.00, 'espresso': 3.00}, 17.00, 23.00)kids = Menu('kids', {'chicken nuggets': 6.50, 'fusilli with wild mushrooms': 12.00, 'apple juice': 3.00}, 11.00, 21.00)flagship_store = Franchise("1232 West End Road", [brunch, early_bird, dinner, kids])new_installment = Franchise("12 East Mulberry Street", [brunch, early_bird, dinner, kids])available_menus = flagship_store.available_menus(12.00)print('Available menus at 12.00 PM:', available_menus)
在上面的代码中,Franchise类的__init__方法接收一个menus参数,这个参数预期是一个Menu对象的列表。Franchise类通过遍历self.menus列表,并调用每个Menu对象的start_time、end_time和name属性来实现其功能。
类型提示
为了提高代码的可读性和可维护性,可以使用类型提示来明确menus参数的类型。
立即学习“Python免费学习笔记(深入)”;
from typing import Listclass Franchise(): def __init__(self, address: str, menus: List[Menu]): self.address = address self.menus = menus
在这个例子中,menus: List[Menu]表示menus参数应该是一个Menu对象的列表。虽然类型提示在运行时不会强制执行类型检查,但它们可以帮助开发者更容易地理解代码的意图,并且可以被静态类型检查工具(如MyPy)用来检测类型错误。
断言
另一种增强代码健壮性的方法是使用断言。断言可以在运行时检查menus参数是否包含Menu对象。
class Franchise(): def __init__(self, address, menus): self.address = address self.menus = menus assert all(isinstance(entry, Menu) for entry in self.menus)
如果menus列表中的任何元素不是Menu类的实例,断言将会失败,并抛出一个AssertionError异常。这可以帮助开发者在早期发现类型错误。
鸭子类型
Python是一种动态类型语言,它使用鸭子类型(Duck Typing)的概念。鸭子类型是指,一个对象的类型并不重要,重要的是它是否具有特定的属性和方法。换句话说,如果一个对象“走起来像鸭子,叫起来像鸭子”,那么它就可以被当作鸭子来使用。
在Franchise类的例子中,只要menus列表中的对象具有start_time、end_time和name属性,available_menus方法就可以正常工作,而不需要这些对象一定是Menu类的实例。
总结
通过实例属性,类型提示和断言,可以在Python中建立类之间的关联,并提高代码的可读性和健壮性。同时,理解Python的鸭子类型概念可以帮助开发者编写更灵活的代码。
以上就是如何在Python中关联类:Franchise与Menu的实例分析的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1375865.html
微信扫一扫
支付宝扫一扫