在__init__函数内部和函数外部定义变量有什么区别

问题描述 投票:0回答:3

我想学习Python中的基础知识并陷入困境。我声明了类变量和实例变量的相同名称,以便我可以更好地理解差异但是当我在类方法中使用类变量时,它显示类似NameError的错误:未定义全局名称'a'。如果类变量和实例变量具有相同的名称,有人可以告诉我如何在类内外声明类变量。下面给出了代码,因此输出错误

class abc:
    a=10
    def __init__(self,a):
        self.a=a
    def mod1(self):
        global a
        a=5
        self.a=105
    def mod2(self):
        a=15
        self.a=110
    def read(self):
        print(self.a)
        print(a)

b=abc(20)
print(b.a)
b.read()
b.mod1()
b.read()
b.mod2()
b.read()

错误是

20
20
Traceback (most recent call last):
  File "/Users/rituagrawal/PycharmProjects/untitled2/code/garbage.py", line 18, in <module>
    b.read()
  File "/Users/rituagrawal/PycharmProjects/untitled2/code/garbage.py", line 14, in read
    print(a)
NameError: global name 'a' is not defined

Process finished with exit code 1
python class oop global-variables
3个回答
1
投票

在类级别设置的属性由类的每个实例共享。

__init__或其他方法中的实例上设置的属性(例如self.a = a)对于每个实例都是不同的,并且在每个方法中都可用。

引用也可以在方法中设置 - a = 15 - 这些只在方法范围内。 print(a)方法中的read()失败,因为在该方法中没有设置a

更新:

一些代码来说明。

class MyClass:
    a = 10

    def __init__(self, b):
        self.b = b

    def read(self):
        c = 99

        print(self.a) # Class attribute - the same for all instances of MyClass
        print(self.b) # Instance attribute - each instance of MyClass has it's own, available in all methods
        print(c) # Local - only available in this method.

0
投票

欢迎来到SO Ritu Agrawal。

self.a 

是一个实例变量,因为你似乎已经猜测了。如果你想引用静态(类)变量a,那么你应该使用:

abc.a

所以:

class abc:
    a=10
    def __init__(self,a):
        self.a=a
        abc.a = 40

b=abc(20)
print(b.a)
print(abc.a)

您还可以使用实例的__class__成员,因此:

class abc:
    a=10
    def __init__(self,a):
        self.a=a
        __class__.a = 40

b=abc(20)
print(b.a)
print(b.__class__.a)

0
投票

首先,我将您的课程简化如下。这里使用a在类函数中引用类变量abc.a。使用a引用作为实例变量的self.a

class abc:

    a=5

    def __init__(self,a):
        self.a=a

    def set(self, class_a, instance_a):

        abc.a=class_a
        self.a=instance_a

    def read(self):

        print(abc.a)
        print(self.a)

然后,我们首先定义类并尝试读取这两个变量。类变量仍为5,实例变量为20

b=abc(20)
b.read()
#5
#20

然后,我设置了类和实例变量a并尝试读取它们。类变量更改为30,实例变量更改为60

b.set(30, 60)
b.read()
#30
#60

我们也可以使用instance_object.a作为实例变量直接访问类外的两个变量,使用ClassName.a作为类变量。

print(b.a)
#30
print(abc.a)
#60
© www.soinside.com 2019 - 2024. All rights reserved.