
本文旨在解释 Python 代码中 Franchise 类与 Menu 类之间的关系。尽管代码中没有显式的连接语句,但 Franchise 类通过其 menus 属性持有 Menu 类的实例,从而建立了关联。本文将深入探讨这种关联方式,并介绍如何通过类型提示和断言来增强代码的清晰度和健壮性。同时,也会介绍python的鸭子类型概念。
在提供的 Python 代码中,Franchise 类和 Menu 类通过 Franchise 类的 menus 属性建立关联。具体来说,Franchise 类的 __init__ 方法接收一个 menus 参数,该参数是一个包含 Menu 类实例的列表。
class Franchise():
  def __init__(self, address, menus):
    self.address = address
    self.menus = menus尽管没有显式的代码行将 Menu 类“连接”到 Franchise 类,但 menus 属性的存在以及它存储 Menu 实例的事实,就已经定义了它们之间的关系。Franchise 对象通过 menus 属性可以访问和管理多个 Menu 对象。
例如,在创建 flagship_store 和 new_installment 对象时,将包含 brunch, early_bird, dinner, kids 这些 Menu 实例的列表传递给了 Franchise 的构造函数。
立即学习“Python免费学习笔记(深入)”;
flagship_store = Franchise("1232 West End Road", [brunch, early_bird, dinner, kids])
new_installment = Franchise("12 East Mulberry Street", [brunch, early_bird, dinner, kids])Franchise 类的 available_menus 方法进一步利用了这种关系,它遍历 self.menus 列表,并根据时间判断哪些菜单可用。
  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虽然上述代码能够正常运行,但为了提高代码的可读性和健壮性,可以使用类型提示和断言来显式地声明 menus 属性的类型。
使用 typing 模块可以为 menus 参数添加类型提示,明确指定它应该是一个包含 Menu 类实例的列表。
from typing import List
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: str, menus: List[Menu]):
    self.address = address
    self.menus = menus这样,IDE 和类型检查器可以帮助开发者更早地发现类型错误。
使用 assert 语句可以在运行时检查 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
    assert all(isinstance(entry, Menu) for entry in self.menus)如果在创建 Franchise 对象时传递了非 Menu 类的实例,断言将会失败并抛出 AssertionError 异常。
需要注意的是,Python 是一种动态类型语言,它采用“鸭子类型”的概念。这意味着,只要一个对象具有所需的方法和属性,就可以将其视为特定类型的对象,而无需显式地声明其类型。
例如,Franchise 类的 available_menus 方法依赖于 Menu 对象的 start_time、end_time 和 name 属性。只要传递给 Franchise 对象的 menus 列表中的对象具有这些属性,该方法就可以正常工作,即使这些对象不是 Menu 类的实例。
使用断言可以防止这种情况的发生,确保 menus 列表中的对象确实是 Menu 类的实例。类型提示只是建议,并不会强制类型。
Franchise 类和 Menu 类之间的关联通过 Franchise 类的 menus 属性建立。可以使用类型提示和断言来增强代码的可读性和健壮性,但需要注意 Python 的鸭子类型概念。选择使用哪种方法取决于具体的需求和代码风格。
以上就是Python 类之间的关联:Franchise 与 Menu 的关系详解的详细内容,更多请关注php中文网其它相关文章!
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号