如何在 Python 类中正确实现折扣方法

发布时间 - 2026-01-26 00:00:00    点击率:

本文详解因缩进错误导致类方法不可访问的问题,通过修复 `apply_discount()` 方法的缩进层级,使其成为类的实例方法而非 `__init__` 内部函数,从而成功对商品价格应用折扣。

在 Python 面向对象编程中,方法的缩进层级直接决定其作用域和可访问性。原始代码中,apply_discount() 和 calculate_total_price() 被错误地缩进至 __init__ 方法内部,导致它们实际成为 __init__ 函数内的局部函数(即闭包),而非 Item 类的实例方法。因此,创建实例后调用 item1.apply_discount() 会触发 AttributeError: 'Item' object has no attribute 'apply_discount'。

✅ 正确做法是:将所有实例方法与 __init__ 并列对齐(同属类体层级),使用 4 空格缩进(PEP 8 推荐),确保它们被定义为类的成员方法。

以下是修复后的完整、可运行代码:

class Item:
    pay_rate = 0.8  # 全局类属性:统一 20% 折扣率

    def __init__(self, name: str, price: float, quantity=0):
        # 参数校验
        assert price >= 0, f"Price {price} is not greater than or equal to zero!"
        assert quantity >= 0, f"Quantity {quantity} is not greater than or equal to zero!"
        # 实例属性赋值
        self.name = name
        self.price = price
        self.quantity = quantity

    def calculate_total_price(self) -> float:
        return self.price * self.quantity

    def apply_discount(self) -> None:
        self.price = self.price * Item.pay_rate  # 使用类属性计算折扣后价格

# 使用示例
item1 = Item("Phone", 100.0, 1)
print(f"原价: {item1.price}")  # 输出: 100.0
item1.apply_discount()
print(f"折后价: {item1.price}")  # 输出: 80.0

? 关键注意事项:

立即学习“Python免费学习笔记(深入)”;

  • ❌ 错误缩进(def apply_discount(...) 缩进在 __init__ 内)→ 方法仅在初始化时存在,且无法被实例调用;
  • ✅ 正确缩进(与 def __init__ 左对齐)→ 方法绑定到类,自动接收 self,可被所有实例调用;
  • Item.pay_rate 是类属性,推荐通过类名访问(而非 self.pay_rate),避免意外被实例覆盖;
  • 若需支持不同商品差异化折扣,可改为实例属性或参数化设计(如 apply_discount(discount_rate=0.8))。

总结:Python 中“缩进即语法”,类中方法必须与 __init__ 同级定义。

一次缩进修正,即可让折扣逻辑真正生效——这是面向对象基础却极易忽略的关键细节。


# python  # app  # 面向对象编程  # 作用域 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何确认建站备案号应放置的具体位置?  如何基于PHP生成高效IDC网络公司建站源码?  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  专业商城网站制作公司有哪些,pi商城官网是哪个?  如何快速生成可下载的建站源码工具?  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  HTML 中动态设置元素 name 属性的正确语法详解  Laravel如何实现本地化和多语言支持?(i18n教程)  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  详解Android——蓝牙技术 带你实现终端间数据传输  C++用Dijkstra(迪杰斯特拉)算法求最短路径  Laravel中的withCount方法怎么高效统计关联模型数量  javascript事件捕获机制【深入分析IE和DOM中的事件模型】  高防服务器如何保障网站安全无虞?  Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率  javascript中的try catch异常捕获机制用法分析  如何用已有域名快速搭建网站?  Laravel Asset编译怎么配置_Laravel Vite前端构建工具使用  文字头像制作网站推荐软件,醒图能自动配文字吗?  EditPlus 正则表达式 实战(3)  如何登录建站主机?访问步骤全解析  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  Laravel如何使用Service Container和依赖注入?(代码示例)  如何在服务器上配置二级域名建站?  Laravel如何使用withoutEvents方法临时禁用模型事件  Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理  Thinkphp 中 distinct 的用法解析  高端建站三要素:定制模板、企业官网与响应式设计优化  浅述节点的创建及常见功能的实现  Laravel如何处理CORS跨域请求?(配置示例)  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  佛山网站制作系统,佛山企业变更地址网上办理步骤?  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  Laravel Admin后台管理框架推荐_Laravel快速开发后台工具  如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  Laravel如何生成和使用数据填充?(Seeder和Factory示例)  Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能  制作企业网站建设方案,怎样建设一个公司网站?  简单实现Android文件上传  微信小程序制作网站有哪些,微信小程序需要做网站吗?  网站制作壁纸教程视频,电脑壁纸网站?  如何在IIS服务器上快速部署高效网站?  laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法  Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  黑客入侵网站服务器的常见手法有哪些?  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  简单实现Android验证码  Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】  如何选择可靠的免备案建站服务器?