Layout di classe Python - Convenzioni

1

Qual è il modo corretto o standard per impaginare una classe. Se una classe in cui avere attributi, metodi, attributi privati, metodi privati, proprietà di classe (metodi) e metodi di classe. Ho fatto il 99% della mia codifica in modo procedurale e oltre a lavorare con ORM non mi sono concentrato molto sull'OOP. Lo sto cambiando in un progetto attuale ed ero solo curioso su quale fosse il modo standard di organizzare le tue lezioni.

Class MyClass():
   attr1 = value1
   attr2 = value2
   _attr3 = value3
   def __init__(self):
      do some stuff
   def do_something(self):
      do some more stuff

   def __do_something_else(self):
      more stuff
   @property()
   def attr4(self):
       return do_some_stuff_else()

   @classmethod()
   def generator_a_bunch_of_these(cls):
       do_some_more_things
    
posta Ominus 06.06.2011 - 15:41
fonte

1 risposta

3

Cerca queste risposte qui: link

I concetti di base sono i più famosi: link

Per l'aspetto e il codice che ho visto, hai una buona idea a riguardo. Buona fortuna, spero che ti aiuti:)

AGGIORNAMENTO: Mentre segui le regole di pep, ti viene in mente lo stesso comunque :) così pura convenzione per le classi - sì non ce n'è nessuna o non ne ho sentito parlare. Come dovresti scriverlo - pep8. Per senso comune di programmazione si scrivono variabili, campi sopra i metodi. Le stesse cose accadono con tutto il resto. Basta codice come lo Zen Santo di Python ti insegna:

  • Beautiful is better than ugly.
  • Explicit is better than implicit.
  • Simple is better than complex.
  • Complex is better than complicated.
  • Flat is better than nested.
  • Sparse is better than dense.
  • Readability counts.
  • Special cases aren't special enough to break the rules.
  • Although practicality beats purity.
  • Errors should never pass silently. Unless explicitly silenced.
  • In the face of ambiguity, refuse the temptation to guess.
  • There should be one - and preferably only one - obvious way to do it.
  • Although that way may not be obvious at first unless you're Dutch.
  • Now is better than never.
  • Although never is often better than right now.
  • If the implementation is hard to explain, it's a bad idea.
  • If the implementation is easy to explain, it may be a good idea.
  • Namespaces are one honking great idea - let's do more of those!
    
risposta data 06.06.2011 - 15:47
fonte

Leggi altre domande sui tag