Pregunta

Estoy creando un contenedor muy simple objeto en python y que una de las funciones requiere para crear un temporal, null marcador de posición de clase que no hace absolutamente nada, excepto para decirle al programa qué eliminar.

class __cyclepass(object):
    "Null class as a placeholder for deleting items in a cycle."""
    pass

class Cycle(object):

    def __init__(self, *args):
        self.l = list(args)

    #.........................

    def __delitem__(self, key):
        """Magic method for deleting items via indexing."""
        try:
            if isinstance(key, slice):
                s = key.start; e = key.stop; stp = key.step if key.step else 1
                slicelen = abs((s - e) // stp)
                if slicelen == 1:
                    steps = [s]
                else:
                    steps = [s + stp * i for i in range(slicelen)]
                _list = copy(self.l)
                for step in steps:
                    index = step % len(self)
                    _list[index] = __cyclepass() #this is where an error occurs
                self.l = list(filter(lambda x: x.__class__ != __cyclepass, _list))
            else:
                index = key % len(self)
                del self.l[index]
        except:
            raise IndexError("Bad index %s" % str(key))

Todo parece estar bien (aunque un poco desordenado pero que está a un lado el punto), pero al momento de ejecutar el programa e implícitamente llamar a la delitem método me sale este error:

NameError: global name '_Cycle__cyclepass' is not defined

Lo que en la tierra podría ser la causa para buscar _Cycle__cyclepass cuando la creación de la __cyclepass objeto?

¿Fue útil?

Solución

[mover mi comentario a una respuesta, como se sugirió]

Este es el resultado de python nombre de destrozarlo de "privado" de los miembros.Cambiar el nombre de un doble subrayado prefijo único carácter de subrayado, y el problema está resuelto.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top