
本文档旨在解释Python中类之间的关联方式,并通过Franchise和Menu类的实例进行说明。我们将探讨如何通过属性将两个类连接起来,以及Python的鸭子类型概念如何影响这种关联。此外,还将介绍使用类型提示和断言来增强代码可读性和健壮性的方法。
在面向对象编程中,类之间的关联通常通过一个类的属性引用另一个类的实例来实现。在提供的Franchise和Menu的例子中,Franchise类通过其menus属性与Menu类关联。menus属性存储Menu类的实例列表。
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_price
class 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_orders
brunch = 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])在上面的代码中,Franchise类的__init__方法接受一个menus参数,并将它赋值给self.menus。 这就建立了Franchise和Menu之间的关联。 Franchise类可以通过访问self.menus来操作相关的Menu对象。
Python 是一种动态类型语言,它使用鸭子类型(Duck Typing)的概念。 鸭子类型意味着一个对象的适用性不是由它的类型决定,而是由它是否具有特定的属性和方法决定。 换句话说,如果一个对象“走起来像鸭子,叫起来像鸭子”,那么它就可以被当作鸭子对待。
立即学习“Python免费学习笔记(深入)”;
在Franchise和Menu的例子中,Franchise类的available_menus方法遍历self.menus列表,并访问每个元素的start_time、end_time和name属性。 只要self.menus中的元素具有这些属性,代码就可以正常运行,而不需要显式地声明这些元素是Menu类的实例。
这种灵活性是 Python 的一个优点,但也可能导致运行时错误。 如果self.menus中的一个元素缺少所需的属性,available_menus方法将会抛出一个AttributeError异常。
为了提高代码的可读性和可维护性,可以使用类型提示(Type Hints)来指定变量的类型。 类型提示不会影响代码的运行,但可以帮助开发者理解代码的意图,并帮助静态分析工具检测类型错误。
在Franchise类的__init__方法中,可以使用typing模块的List类型提示来指定menus参数的类型为Menu对象的列表。
from typing import List
class Franchise():
  def __init__(self, address: str, menus: List[Menu]):
    self.address = address
    self.menus = menus在这个例子中,address: str表示address参数的类型为字符串,menus: List[Menu]表示menus参数的类型为Menu对象的列表。
除了类型提示之外,还可以使用断言(Assertions)在运行时检查变量的类型。 断言是一种调试工具,用于在代码中插入一些检查点,以确保代码的状态符合预期。
在Franchise类的__init__方法中,可以使用assert语句来检查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)在这个例子中,assert all(isinstance(entry, Menu) for entry in self.menus)语句会检查menus列表中的每个元素是否都是Menu类的实例。 如果有一个元素不是Menu类的实例,断言将会失败,并抛出一个AssertionError异常。
通过属性引用,我们可以在 Python 中建立类之间的关联。 虽然 Python 的鸭子类型提供了灵活性,但使用类型提示和断言可以提高代码的可读性和健壮性。 选择哪种方法取决于具体的应用场景和开发需求。 类型提示主要用于静态分析和提高代码可读性,而断言则用于在运行时进行类型检查和调试。
以上就是如何在Python中关联类:以Franchise和Menu类为例的详细内容,更多请关注php中文网其它相关文章!
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号