24

我在运行这段代码时遇到问题。该类是具有 IdCounter 的 Student,这似乎是问题所在。(第 8 行)

class Student:
    idCounter = 0
    def __init__(self):
        self.gpa = 0
        self.record = {}
        # Each time I create a new student, the idCounter increment
        idCounter += 1
        self.name = 'Student {0}'.format(Student.idCounter)

classRoster = [] # List of students
for number in range(25):
    newStudent = Student()
    classRoster.append(newStudent)
    print(newStudent.name)

我试图在我的Student班级中使用这个 idCounter,所以我可以将它作为学生姓名的一部分(例如,这实际上是一个 ID# Student 12345。但我一直出错。

Traceback (most recent call last):
  File "/Users/yanwchan/Documents/test.py", line 13, in <module>
    newStudent = Student()
  File "/Users/yanwchan/Documents/test.py", line 8, in __init__
    idCounter += 1
UnboundLocalError: local variable 'idCounter' referenced before assignment

我试图将 idCounter += 1 放在之前,之后,所有组合中,但我仍然收到referenced before assignment错误,你能向我解释我做错了什么吗?

4

2 回答 2

41

类变量必须通过类名访问,在本例中Studend.idCounter

class Student:
    # A student ID counter
    idCounter = 0
    def __init__(self):
        self.gpa = 0
        self.record = {}
        # Each time I create a new student, the idCounter increment
        Student.idCounter += 1
        self.name = 'Student {0}'.format(Student.idCounter)

classRoster = [] # List of students
for number in range(25):
    newStudent = Student()
    classRoster.append(newStudent)
    print(newStudent.name)

感谢 Ignacio 的指出,Vazquez-Abrams 明白了……

于 2012-04-04T05:31:52.487 回答
1

前段时间得到这个答案帮助我找到了整理类与实例变量及其作用域所需的内容。所以,一个扩展,它做同样的事情,只使用一个生成器。生成器像 idCounter 一样为学生分配一个唯一编号——只有它使用这些值。我知道生成器类上没有prev方法。idGenerator 和 idCounter 都没有被记忆,所以如果你想外部化列表然后回来添加一个或多个学生,你必须相应地更新 range(start,,),或者迭代每个值而不分配它,直到你依次到达唯一的一个,使用 idCounter 的路径稍微短一些,您可以使用单个虚拟实例构造简单地设置它并继续。

class Student:
    """ Implement a shared generator among all sub-classes
    in addition to idCounter. """

    # A student ID counter
    idCounter = 0
    # A student ID from generator
    idGenerator = (x for x in range(0xAAAAAA, 0xEEEEEE, 0xBA))

    def __init__(self):
        self.gpa = 0
        self.record = {}
        # Each time I create a new student, the idCounter increment
        Student.idCounter += 1
        self.id = Student.idGenerator.__next__()
        self.name = f"{self.id} Student {Student.idCounter}"

classRoster = [] # List of students
for number in range(25):
    newStudent = Student()
    classRoster.append(newStudent)
    print(newStudent.name)
于 2018-07-12T22:59:54.587 回答