一、Python 中类的属性分为实例属性和类属性,属性就是附在对象后可被引用的函数或者数据。通常我们将类中的函数又称为类的方法。
1、类属性
class MyClass(object):
"""docstring for MyClass"""
test_name = "MyClass"
def __init__(self, name, ege):
self.name = name
self.ege = ege
def func(self):
print MyClass.name
class1 = MyClass("alice", 18)
class2 = MyClass("atlas", 19)
print MyClass.test_name
print class1.test_name
print class2.test_name
在这里我们定义一个类对象并将其赋给MyClass变量名,在类中我们定义了类属性test_name,在例子中我们创建两个MyClass的实例class1,class2对于类属性我们可以通过类和实例获取,每初始化一个实例都将一致的获得其类属性,同时实例可以去自行更改这些属性,在类的内部需要通过(classname.类属性名)来引用类属性对象。
2、实例属性
通常在类中通过初始化函数__init__()中实现,在__init__中初始化的属性属于类实例的实例属性,在类的外部需要通过类的实例对象去读取例如我们上面例子中需要通过
class1.name或者 class1.ege来获取属性的值。不同的实例其实例属性通常不一样
3、私有属性
Python中并没有真正的私有属性概念
1、单下划线_开头,这是告诉别人这是私有属性,但是依然可以访问这个模块,其作用在于当我们在一个模块a.py中定义了带单下划线的属性时,若b.py通过 from a import *导入时候无法直接引入带单下划线的私有属性,但是通过import a导入的话可以通过a._属性名访问。看下面这个例子:
/*a.py*/
_name = "alice"
name = "atlas"
/*b.py*/
_name = "alice"
name = "atlas"
执行b.py得到结果如下
atlaTraceback (most recent call last):
File "C:\report\b.py", line 3, in
s
print _name
NameError: name '_name' is not defined
[Finished in 0.3s]
如果我们将b.py改为以下部分的话
/*b.py*/
import a
print a.name
print a._name
得到结果
atlas
alice
[Finished in 0.4s]
综上所述带单下划线的属性也并非真正实现了静态变量隔离访问的目的,同样可以通过模块名.属性名的方式来获取到对属性的访问。
2、带双下划线的属性访问
在类中我们通过用开头双下划线结尾以至多一个下划线来定义私有变量名。例如在下面例子中我们定义一个类属性__name,初始化一个实例class_1,接着访问__name属性
class MyClass(object):
"""docstring for MyClass"""
__name = "alice"
def __init__(self, name, ege):
self.name = name
self.ege = ege
def func(self):
print MyClass.name
class_1 = MyClass("sookie", 25)
class_1.__name
得到结果:
Traceback (most recent call last):
File "C:\Users\tongfei\Desktop\testfile\ClassTest.py", line 10, in
print class_1.__name
AttributeError: 'MyClass' object has no attribute '__name'
我们来通过dir(MyClass),查看下MyClass中包含的属性:
['_MyClass__name', '__class__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattribute__', '__hash__', '__init__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'func']
刚才我们定义的__name私有属性在这里已经变为_MyClass_name,现在我们试着通过class_1._MyClass__name来访问该类属性,得到结果如下:
alice
[Finished in 0.3s]
所以综上讨论Python中并未提供类似C++/Java中类似的public和private来控制对类中属性的私有和非私有的访问控制。