2010-07-28 8 views

Répondre

2

D'abord, vous définissez une classe MainString. Dans la méthode __init__ (le constructeur), vous créez les variables d'instance (Sub1, etc.):

class MainString(object): 
    def __init__(self): 
     self.Sub1 = "" 
     self.Sub2 = "" 
     self.Sub3 = "" 

Ensuite, vous créez une instance de la classe. Vous pouvez modifier la valeur des variables d'instance pour cette instance:

StringNumberOne = MainString() 
StringNumberOne.Sub1 = "hello" 
2

Je suis Je ne sais pas si je comprends votre question. Vous pouvez habe une classe comme ceci:

class ManySubs(object): # explicit inheritance not needed in 3.x 
    def __init__(self, *subs): 
     self._subs = subs 
     # add sub1..subN fields, but only because you asked for it 
     # I think a dynamic fields are an especially bad idea 
     # plus, about everytime you have x1..xN, you actually want an array/list 
     for i in range(len(subs)): 
      setattr(self, 'sub'+str(i+1), subs[i]) 

    # wrapping code for sequencemethods (__len__, __getitem__, etc) 

    def __str__(self): 
     return ''.join(self._subs) 
+1

ci-dessus manquant '' def' à __str__' – bstpierre

4

Il y a aussi l'approche tuple nommée:

Code
from collections import namedtuple 

Mainstring = namedtuple('Mainstring', 'sub1 sub2 sub3') 

example = Mainstring("a", "b", "c") 
print example.sub1 # "a"