2011-09-10 11 views
5

Quindi ho questo codice sotto per un oggetto Tabella, e ha una proprietà per nomi di campo.descrittore 'getter' richiede un oggetto 'proprietà' ma ha ricevuto una 'funzione'

class Table(object): 
    '''A CSV backed SQL table.''' 
    @property 
    def fieldnames(self): 
     with open(self.filename) as f: 
      return csv.DictReader(f).fieldnames 

    @property.setter 
    def fieldnames(self, fieldnames): 
     with open(self.filename, 'w') as f: 
      dr = csv.reader(f) 
      dw = csv.DictWriter(f, fieldnames=fieldnames) 
      dw.writerow(dict((field, field) for field in fieldnames)) 
      for row in self: 
       dw.writerow(row) 

Quando provo ad importare il file, ottengo l'errore:

seas486:PennAppSuite ceasarbautista$ python 
Python 2.7.1 (r271:86832, Jun 25 2011, 05:09:01) 
[GCC 4.2.1 (Based on Apple Inc. build 5658) (LLVM build 2335.15.00)] on darwin 
Type "help", "copyright", "credits" or "license" for more information. 
>>> import table 
Traceback (most recent call last): 
    File "<stdin>", line 1, in <module> 
    File "table.py", line 7, in <module> 
    class Table(object): 
    File "table.py", line 9, in Table 
    @property.getter 
TypeError: descriptor 'getter' requires a 'property' object but received a 'function' 

Qualcuno può spiegare cosa significa questo errore?

risposta

16

Suppongo che sia l'equivalente a TypeError: unbound method ... must be called with ... instance as first argument (got ... instance instead). Per aggiungere un setter a una proprietà tramite un decoratore, è necessario utilizzare .setter come membro/metodo dell'oggetto proprietà, non come metodo statico/classmethod di property. Il codice dovrebbe assomigliare a questo:

class Table(object): 
    '''A CSV backed SQL table.''' 
    @property 
    def fieldnames(self): 
     with open(self.filename) as f: 
      return csv.DictReader(f).fieldnames 

    @fieldnames.setter # <<< 
    def fieldnames(self, fieldnames): 
     with open(self.filename, 'w') as f: 
      dr = csv.reader(f) 
      dw = csv.DictWriter(f, fieldnames=fieldnames) 
      dw.writerow(dict((field, field) for field in fieldnames)) 
      for row in self: 
       dw.writerow(row) 

vedere anche l'esempio nella documentation.

Problemi correlati