在python中将对象附加到全局列表

2024-10-06 10:28:32 发布

您现在位置:Python中文网/ 问答频道 /正文

我试图让用户制作一个名为NoteSet的对象,每个NoteSet都将被放入一个名为db的全局列表中。这是我的尝试:

import sys
import datetime
db = list()
class NoteSet:
    nextseqNum = 0
    def __init__(self,name,description,hidden):
        global db
        self.seqNum = Note.nextseqNum
        self.name        = name
        self.description = description
        self.dateCreated = datetime.date.today()
        self.hidden      = hidden
        self.notes       = list()
        db[self.seqNum]  = self
        print(self)
        print(len(db))
        Note.nextseqNum  += 1

例如,当我尝试创建对象时:

^{pr2}$

它给了我错误

Traceback (most recent call last): File "", line 1, in NoteSet('example','ex',True) File "C:\Users\Brandon\Desktop\step5.py", line 22, in init db[self.seqNum] = self IndexError: list assignment index out of range

这是生成全局对象列表的正确方法吗?在


Tags: 对象nameimportself列表dbdatetimeinit
2条回答

出现此错误是因为db中没有元素(python列表被初始化为长度为0),因此当您尝试替换位于self.seqNum的元素时,您正在访问一个无效的索引。这与它的全球性无关。在

如果我们假设只能以线程安全的方式访问这个全局列表,那么您应该能够:

db.appened(self)

相反。然而,正如注释中提到的,如果这个类是与db列表接口的“看门人”,那么在这个用例中,使db成为一个类变量更有意义。在

更新

为了在评论中回答OP的问题

I am looking to be able to keep track of the location of the objects in the list by the seqNum

如前所述,seqNum将永远线性递增,与每个新的NoteSet实例一起。如果我们假设Note.nextseqNum的线程安全访问,那么通过db[self.seqNum]所做的事情已经通过db.append(self)隐式地完成了,因为len(db) == Note.nextseqNum总是这样。现在,我们将忽略如果您可以从db中删除元素会发生什么,因为现在您的系统根本不考虑这个问题,无论如何都会完全崩溃。在

但是,如果将来seqNum不是每次生成一个新实例时都单调地增加,那么您可以简单地使db变成dict,而不是list

^{pr2}$

然后将新实例完全插入到它中

db[self.seqNum] = self

db现在显式表示seqNumNoteSet映射,而不是基于数组索引的隐式关系。在

实际上,我还是建议这样做,因为它还可以解决从db中“免费”删除项的问题。也就是说,对于删除的实例之后的任何实例,执行del db[instance.seqNum]操作将使seqNum到{}的所有映射完全无效。但是如果db是一个dict,那么这个操作会按照您的预期操作,并且所有的{}值仍然映射到db中的正确实例。在

因此,为了把它们结合起来,我建议您将类更改为如下所示:

import sys
import datetime

class NoteSet:
    nextseqNum = 0
    db         = dict()

    def __init__(self,name,description,hidden):
        self.seqNum      = NoteSet.nextseqNum
        self.name        = name
        self.description = description
        self.dateCreated = datetime.date.today()
        self.hidden      = hidden
        self.notes       = list()
        NoteSet.db[self.seqNum]  = self
        print(self)
        print(len(db))
        NoteSet.nextseqNum  += 1

正如@aruisdante所说,你需要在列表中附加

试试这个:

db = []

class ListObj:
    def __init__(self, name, msg, hide=False):
        self.name = name
        self.msg = msg
        self.hide = hide
        db.append(self)

祝你好运!在

相关问题 更多 >