Python类的构造方法 __init__及super().__init__

2024-04-01 02:04

本文主要是介绍Python类的构造方法 __init__及super().__init__,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

__init__ 是 Python 中特殊的方法,__init__ 构造方法在对象被创建时自动调用,用于在创建类的实例时进行初始化新创建的对象的状态。在这个方法内部,可以设置对象的初始属性,或者执行其他必要的初始化操作。

class ClassName:def __init__(self, param1, param2, ...):# 初始化操作,设置对象的初始属性等self.param1 = param1self.param2 = param2# 其他初始化操作...# 创建类的实例
obj = ClassName(value1, value2, ...)

在构造方法中,self 表示当前对象自身,它是 Python 中的约定俗成的命名方式,用于引用对象的属性和方法。构造方法的参数列表除了 self 外,可以包含任意数量的参数,用于初始化对象的属性。在构造方法中,可以通过 self 来访问和设置对象的属性,以及调用对象的方法。

class Person:def __init__(self, name, age):self.name = name  # 设置初始属性 nameself.age = age    # 设置初始属性 ageself.is_adult = age >= 18  # 根据年龄设置是否成年的属性def greet(self):print(f"Hello, my name is {self.name} and I am {self.age} years old.")# 创建一个 Person 对象
person1 = Person("Alice", 25)# 调用 greet 方法
person1.greet()  # 输出 "Hello, my name is Alice and I am 25 years old."# 访问对象的属性
print(person1.name)      # 输出 "Alice"
print(person1.age)       # 输出 25
print(person1.is_adult)  # 输出 True

 在上面的示例中,__init__ 方法设置了 nameage 两个初始属性,并根据 age 属性的值设置了 is_adult 属性。这样,在创建 Person 对象时,这些属性会被正确地初始化。

-----

super().__init__ 是 Python 中用于调用父类(超类)的构造方法的一种方式。它通常用于子类的构造方法中,以便在子类的构造方法中执行父类的初始化操作。

在 Python 中,如果子类的构造方法中没有显式调用父类的构造方法,那么 Python 会默认调用父类的无参数构造方法。但是,如果父类的构造方法需要接收参数,并且子类也需要对这些参数进行初始化,那么就需要使用 super().__init__ 来显式调用父类的构造方法,并传入相应的参数。

下面是一个示例,演示了如何在子类的构造方法中使用 super().__init__ 调用父类的构造方法

class Parent:def __init__(self, name):self.name = namedef greet(self):print(f"Hello, I'm {self.name}.")class Child(Parent):def __init__(self, name, age):super().__init__(name)  # 调用父类的构造方法,传入 name 参数self.age = agedef greet(self):super().greet()  # 调用父类的 greet 方法print(f"I am {self.age} years old.")# 创建子类的实例
child = Child("Alice", 10)# 调用子类的 greet 方法
child.greet()

 在上面的示例中,Child 类继承自 Parent 类,Child 类的构造方法中使用 super().__init__(name) 调用了父类 Parent 的构造方法,并传入了 name 参数。这样,在创建 Child 类的实例时,会先调用父类 Parent 的构造方法,进行父类属性的初始化,然后再执行子类 Child 的构造方法,进行子类属性的初始化。

----------

在Python中,私有属性和方法是指以双下划线开头但不以双下划线结尾的属性和方法。
这种命名约定被称为名称修饰(name mangling),它可以使属性和方法对外部不可见,只能在类的内部使用。
私有属性和方法的主要目的是封装类的内部实现细节,防止外部直接访问或修改这些属性和方法。

class MyClass:def __init__(self):self.public_attribute = "Public attribute"  # 公有属性self.__private_attribute = "Private attribute"  # 私有属性def public_method(self):print("Public method called")def __private_method(self):print("Private method called")def access_private_method(self):self.__private_method()  # 在类内部可以访问私有方法obj = MyClass()# 访问公有属性和方法
print(obj.public_attribute)
obj.public_method()# 访问私有属性和方法(在类外部无法直接访问)
# print(obj.__private_attribute)  # 这行代码会报错 AttributeError
# obj.__private_method()  # 这行代码会报错 AttributeError# 通过调用公有方法访问私有属性和方法
obj.access_private_method()# 在上面的代码中,__private_attribute 和 __private_method() 都是私有属性和方法,外部无法直接访问。
# 但是,我们可以通过公有方法如 access_private_method() 来间接访问私有属性和方法。
class BankAccount:def __init__(self, balance=0):self.__balance = balancedef deposit(self, amount):if amount < 0:raise ValueError("Deposit amount must be positive")self.__balance += amountdef withdraw(self, amount):if amount < 0:raise ValueError("Withdrawal amount must be positive")if amount > self.__balance:raise ValueError("Insufficient funds")self.__balance -= amountdef get_balance(self):return self.__balance@propertydef balance(self):return self.__balance# __str__方法是一个特殊的Python方法,它用于定义一个对象在print()函数或者其他需要将对象转换为字符串的情况下,返回的字符串表示。def __str__(self):return f"BankAccount(balance: {self.__balance})"# 创建一个BankAccount实例
account = BankAccount()# 存款
account.deposit(100)# 查看余额
print('get_balance查看余额:',account.get_balance())# 取款
account.withdraw(50)# 查看余额
print('get_balance查看余额:',account.get_balance())# 使用balance属性访问器方法访问余额
print('访问器方法访问余额:',account.balance)# 打印账户对象
print(account)

在这个示例中,我们创建了一个BankAccount实例,然后使用了depositwithdrawget_balancebalance属性访问器方法和__str__方法。这些方法和属性的应用如下:

  • withdraw方法用于从账户中取出50元,确保在取款后余额仍然正数。
  • balance属性访问器方法用于简单地访问账户的余额,这里使用它访问了账户的余额。
  • __str__方法用于直观地打印账户对象,这里使用它打印了账户对象。

这篇关于Python类的构造方法 __init__及super().__init__的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/865959

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e