赞
踩
在Python中定义类经常会用到__init__函数(方法)和__init.py文件,下面对__init__()方法和__init__.py的作用和意义谈下个人理解。
__init__方法是Python当中的一个内置方法,例如在Student类时,把number、name、score等属性绑上去:
- class Student:
- def __init__(self,number,name,score):
- self.number = number
- self.name = name
- self.score = score
'运行
这里注意:(1)__init__方法的第一参数永远是self,表示创建的类实例本身,因此,在__init__方法内部,就可以把各种属性绑定到self,因为self就指向创建的实例本身。(2)有了__init__方法,在创建实例的时候,就不能传入空的参数了(会报错),必须传入与__init__方法匹配的参数,但self不需要传,Python解释器会自己把实例变量传进去:
- class Student:
- def __init__(self,number,name,score):
- self.number = number
- self.name = name
- self.score = score
- def student_number(self):
- print('学号:',self.number)
- def student_name(self):
- print('姓名:',self.name)
- def student_score(self):
- print('分数:',self.score)
-
- student=Student(20230101,'小明',99)
- student.student_number()
'运行
这里self就是指类本身,self.name就是Student类的属性变量,是Student类所有。而name是外部传来的参数,不是Student类所自带的。故,self.name = name的意思就是把外部传来的参数name的值赋值给Student类自己的属性变量self.name。
输出结果:
学号: 20230101
和普通函数相比,在类中定义__init__函数只有一点不同,就是第一参数永远是类的本身实例变量self,并且调用时,不用传递该参数。除此之外,__init__方法(函数)和普通函数没啥区别,你既可以用默认参数、可变参数或者关键字参数(args是可变参数,args接收的是一个tuple,*kw是关键字参数,kw接收的是一个dict)
print(student.__dict__)
输出结果:
{'number': 20230101, 'name': '小明', 'score': 99}
'运行
从上面的结果可以看到定义完init()后,创建的每个实例都有自己的属性,可以直接调用类中的函数。
- class Student:
- def student_number(self,number):
- print('学号:',number)
- def student_name(self,name):
- print('姓名:',name)
- def student_score(self,score):
- print('分数:',score)
-
- student = Student()
- student.student_number('20230101')
- print(student.__dict__)
'运行
输出结果:
- 学号: 20230101
- {}
从上例中可以看到,我们在类中并没有定义init()方法,但是也能够得到类似的要求,结果返回了学号信息。但是我们通过print(rect.dict)来看这个实例的属性,竟然是空的,我定义了一个Student类,按理来说它的属性应该是学号、姓名和分数。但是它竟然没有,这就是没有定义init()的原因了。
在实例化对象的时候,student = Student()参数为空,没有指定number、name、score的值,只有在调用函数的时候才指定了。且类中定义的每个方法的参数都有number、name、score,这显然浪费感情,在类中直接指定方法就可以了。因此需要在类中定义init()方法,方便创建实例的时候,需要给实例绑定上属性,也方便类中的方法(函数)的定义。
- class Student:
- def __init__(self):
- self.number = None
- self.name = None
- self.score = None
- def student_number(self):
- print('学号:',self.number)
- def student_name(self):
- print('姓名:',self.name)
- def student_score(self):
- print('分数:',self.score)
-
- student = Student()
- student.number = '20230101'
- student.student_number()
- print(student.__dict__)
'运行
输出结果:
- 学号: 20230101
- {'number': '20230101', 'name': None, 'score': None}
Pycharm创建相关的项目时,常常会看到 __init__.py,当你使用某些编辑器创建 Python Package 的时候,它也会自动给你生成一个 __init__.py 文件,那么__init__.py的用途是什么呢?
我们知道, Python 中的包是可以包含多个 py 模块的,我们可以在不同的地方通过包名区分使用这些模块。其实在 Python3.2 版本之前,定义的 Package 下面一定要有 __init__.py 文件,这样 Python 才知道它是一个 Package,才可以寻找到相关模块的路径从而被 import。而在 Python3.2 之后的版本就不需要再额外的去专门创建一个 __init__.py 来告诉 Python 它是一个 Package 了,因为现在创建的包叫 Namespace package, Python 可以自动搜寻 Package 路径,哪怕你的父包路径发生了改变,你在下次导入的时候, Python 还是会自动重新搜索包路径。
另外,__init__.py 会在 import 的时候被执行,虽然空的 __init__.py 在 Python 新版本中已经不需要你额外去定义了,因为就算你不定义 init, Python 也知道你导入的包路径,但是如果你想要做一些初始化操作当然,例如我们想预先导入相关的模块,那么定义 __init__.py 还是很有必要的。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。