如何在 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__ 同级定义。

相关栏目:
【
网站优化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模型常用查询逻辑封装技巧【手册】
如何选择可靠的免备案建站服务器?

