__getitem__, __setitem__ 多个键

Bar*_*ley 5 python class datamodel magic-methods

我正在尝试创建一个将数据存储在本地缓冲区中并充当数据库接口的类。我有以下代码:

class Table(object):    
    def __init__(self, tableName, **columnDict):
       self.tableName      = tableName
       self.columns        = {}
       self.types          = {}
       self.columns['id']  = []
       self.types['id']    = 'INT PRIMARY KEY NOT NULL'
       for name in columnDict:
           self.columns[name] = []
           self.types[name]    = columnDict[name]

    def updateBufferRow(self, index, updateDict):
       for key in updateDict:
           self.columns[key][index] = updateDict[key]

    def getBufferRow(self, index):
       row = {}
       for key in self.columns:
           row[key] = self.columns[key][index]
       return row

    def __getitem__(self, key, **args):
       """ Allows using self[key] method """
       return self.getBufferRow(key)

    def __setitem__(self, key, value, **args):
       """ Allows using self[key] = value method """
       self.updateBufferRow(key, value)
Run Code Online (Sandbox Code Playgroud)

这是我初始化表的方式:

testTable = Table('BestTable', test = 'TestType', test2='INT')
Run Code Online (Sandbox Code Playgroud)

如果我尝试,它会按预期工作:

testTable[0]['test'] = "LALALA"
Run Code Online (Sandbox Code Playgroud)

它什么都不做,另一方面,它会更新而不是覆盖表:

testTable[0] = {"test": "LALALA"}
Run Code Online (Sandbox Code Playgroud)

我知道我必须重写 updateBufferRow() 和 getBufferRow() 方法,唯一我不太确定的是如何使用 _ getitem _ 和 _ setitem _ 方法获取多个键。

Mar*_*ers 3

dict您返回的内容__getitem__与您的列不再有任何关系。您需要返回一些可能看起来像dict但将回调映射__setattr__回表列的内容:

class Row(dict):
    def __init__(self, table, index, *args, **kw):
        self._table, self._index = table, index
        super(Row, self).__init__(*args, **kw)

    def __setitem__(self, key, value):
        super(Row, self).__setitem__(key, value)
        self._table.columns[key][self._index] = value
Run Code Online (Sandbox Code Playgroud)

然后返回它而不是常规的dict

def getBufferRow(self, index):
   row = {}
   for key in self.columns:
       row[key] = self.columns[key][index]
   return Row(self, index, row)
Run Code Online (Sandbox Code Playgroud)