访问实例属性和类属性之间的区别

Naz*_*san 3 python class instance

我有一个Python类

class pytest:
    i = 34
    def func(self):
        return "hello world"
Run Code Online (Sandbox Code Playgroud)

当我访问时pytest.i,我得到34.我也可以这样做:

a = pytest()
a.i
Run Code Online (Sandbox Code Playgroud)

这也给了34.

如果我试图访问(不存在)pytest.j,我得到

Traceback (most recent call last):
File "<pyshell#6>", line 1, in <module>
pytest.j
AttributeError: class pytest has no attribute 'j'
Run Code Online (Sandbox Code Playgroud)

当我尝试时a.j,错误是

Traceback (most recent call last):
File "<pyshell#8>", line 1, in <module>
a.j
AttributeError: pytest instance has no attribute 'j'
Run Code Online (Sandbox Code Playgroud)

所以我的问题是:两种情况到底发生了什么,有什么区别?

Aar*_*lla 7

不,这是两件不同的事情.

在Python中,一切都是对象.类是对象,函数是对象,实例是对象.由于一切都是对象,所以一切都以类似的方式运行.在您的情况下,您创建一个类实例(==具有类型"Class"的对象),名称为"pytest".该对象有两个属性:ifuc.i是"Integer"或"Number" fuc的实例,是"Function"的实例.

当你使用"pytest.j"时,你告诉python"查找对象pytest,当你拥有它时,查找i"."pytest"是一个类实例,但这并不重要.

当您创建"pytest"实例(==具有"pytest"类型的对象)时,您有一个具有"默认值"的对象.在您的情况下,a是一个实例pytest,意味着apytest在下一个中搜索无法找到的任何内容.

所以a.j意味着:"看看a.当它不存在时,也要看看pytest".但是j不存在,Python现在必须给你一个有意义的错误信息.它可以说"类pytest没有属性'j'".这将是正确的,但毫无意义的:你必须弄清楚自己,你试图访问j通过a.这会令人困惑.圭多不会那样.

因此,python使用不同的错误消息.由于它并不总是具有instance(a)的名称,因此设计者决定使用该类型,因此您将获得"pytest instance ...".