¿Hay alguna forma de evitar llamar a __init__
en una clase mientras se inicializa, como por ejemplo desde un método de clase?Python: crear una instancia de clase sin invocar el inicializador
Intento crear una clase de cadena insensible a mayúsculas y minúsculas en Python, utilizada para fines de comparación eficiente, pero tengo problemas para crear una nueva instancia sin llamar al __init__
.
>>> class String:
def __init__(self, string):
self.__string = tuple(string.split())
self.__simple = tuple(self.__simple())
def __simple(self):
letter = lambda s: ''.join(filter(lambda s: 'a' <= s <= 'z', s))
return filter(bool, map(letter, map(str.lower, self.__string)))
def __eq__(self, other):
assert isinstance(other, String)
return self.__simple == other.__simple
def __getitem__(self, key):
assert isinstance(key, slice)
string = String()
string.__string = self.__string[key]
string.__simple = self.__simple[key]
return string
def __iter__(self):
return iter(self.__string)
>>> String('Hello, world!')[1:]
Traceback (most recent call last):
File "<pyshell#2>", line 1, in <module>
String('Hello, world!')[1:]
File "<pyshell#1>", line 17, in __getitem__
string = String()
TypeError: __init__() takes exactly 2 positional arguments (1 given)
>>>
¿Qué debería reemplazar con string = String(); string.__string = self.__string[key]; string.__simple = self.__simple[key]
para inicializar el nuevo objeto con las rebanadas?
EDIT:
Como se inspira en la respuesta escrita a continuación, el inicializador ha sido editado para comprobar rápidamente para ningún argumento.
def __init__(self, string=None):
if string is None:
self.__string = self.__simple =()
else:
self.__string = tuple(string.split())
self.__simple = tuple(self.__simple())
posible duplicado de [¿Hay una manera de crear una instancia de una clase sin tener que llamar \ _ \ _ init \ _ \ _?] (Http: // stackoverflow.com/questions/6383914/is-there-a-way-to-instanceiate-a-class-without-calling-init) – kay