"""
Necesito código Python para una clase que
contenga el nombre, apellidos. email y fecha de nacimiento
de una persona. Toda esta información será accesible
a través de propiedades de solo lectura.
Un método str convertirá la información
en cadena de caracteres.
Además, la clase Empleado derivada de persona
contiene la información de la empresa
para la que trabaja,
lo publica como propiedad de solo lectura,
y también provee de un método str que convierte
toda la información a cadena de caracteres.
La clase estudiante derivada de persona contiene
la institución, el nombre del grado y
el número de curso (1 a 4).
Toda esta información también se publica
como propiedades de solo lectura y también ofrece
un método str que convierte toda la información
a cadena de caracteres.
Finalmente, la clase PersonaRepo contiene
una lista de personas, un método str
que devuelve toda la información de
todas las personas (una por línea),
y una propiedad de solo lectura personas
que devuelve una lista de personas.
Además, el método busca admite una lambda
que permite ejecutar un filtrado
de las personas almacenadas.
"""
# Blackbox
from datetime import datetime
class Persona:
def __init__(self, nombre, apellidos, email, fecha_nacimiento):
self._nombre = nombre
self._apellidos = apellidos
self._email = email
self._fecha_nacimiento = fecha_nacimiento
@property
def nombre(self):
return self._nombre
@property
def apellidos(self):
return self._apellidos
@property
def email(self):
return self._email
@property
def fecha_nacimiento(self):
return self._fecha_nacimiento
def __str__(self):
return f"{self.nombre} {self.apellidos} - {self.email} - {self.fecha_nacimiento.strftime('%d/%m/%Y')}"
class Empleado(Persona):
def __init__(self, nombre, apellidos, email, fecha_nacimiento, empresa):
super().__init__(nombre, apellidos, email, fecha_nacimiento)
self._empresa = empresa
@property
def empresa(self):
return self._empresa
def __str__(self):
return f"{super().__str__()} - {self.empresa}"
class Estudiante(Persona):
def __init__(self, nombre, apellidos, email, fecha_nacimiento, institucion, nombre_grado, curso):
super().__init__(nombre, apellidos, email, fecha_nacimiento)
self._institucion = institucion
self._nombre_grado = nombre_grado
self._curso = curso
@property
def institucion(self):
return self._institucion
@property
def nombre_grado(self):
return self._nombre_grado
@property
def curso(self):
return self._curso
def __str__(self):
return f"{super().__str__()} - {self.institucion} - {self.nombre_grado} - Curso {self.curso}"
class PersonaRepo:
def __init__(self):
self._personas = []
@property
def personas(self):
return self._personas
def buscar(self, filtro):
return [p for p in self._personas if filtro(p)]
def __str__(self):
# Modificado self._persona por self._personas
return "\n".join(str(p) for p in self._personas)
def agregar_persona(self, persona):
self._personas.append(persona)
repo = PersonaRepo()
p1 = Persona("Juan", "Pérez", "juan@example.com", datetime(1990, 1, 1))
p2 = Empleado("María", "González", "maria@example.com", datetime(1992, 2, 2), "Empresa XYZ")
p3 = Estudiante("Pedro", "Rodríguez", "pedro@example.com", datetime(1995, 3, 3), "Universidad ABC", "Ingeniería", 2)
repo.agregar_persona(p1)
repo.agregar_persona(p2)
repo.agregar_persona(p3)
print(repo)
# Buscar personas que tienen más de 25 años
mayores_de_25 = repo.buscar(lambda p: (datetime.now() - p.fecha_nacimiento).days // 365 > 25)
print("Mayores de 25 años:")
for p in mayores_de_25:
print(p)
IiIiCk5lY2VzaXRvIGPDs2RpZ28gUHl0aG9uIHBhcmEgdW5hIGNsYXNlIHF1ZQpjb250ZW5nYSBlbCBub21icmUsIGFwZWxsaWRvcy4gZW1haWwgeSBmZWNoYSBkZSBuYWNpbWllbnRvCmRlIHVuYSBwZXJzb25hLiBUb2RhIGVzdGEgaW5mb3JtYWNpw7NuIHNlcsOhIGFjY2VzaWJsZQphIHRyYXbDqXMgZGUgcHJvcGllZGFkZXMgZGUgc29sbyBsZWN0dXJhLgpVbiBtw6l0b2RvIHN0ciBjb252ZXJ0aXLDoSBsYSBpbmZvcm1hY2nDs24KZW4gY2FkZW5hIGRlIGNhcmFjdGVyZXMuCkFkZW3DoXMsIGxhIGNsYXNlIEVtcGxlYWRvIGRlcml2YWRhIGRlIHBlcnNvbmEKY29udGllbmUgbGEgaW5mb3JtYWNpw7NuIGRlIGxhIGVtcHJlc2EKcGFyYSBsYSBxdWUgdHJhYmFqYSwKbG8gcHVibGljYSBjb21vIHByb3BpZWRhZCBkZSBzb2xvIGxlY3R1cmEsCnkgdGFtYmnDqW4gcHJvdmVlIGRlIHVuIG3DqXRvZG8gc3RyIHF1ZSBjb252aWVydGUKdG9kYSBsYSBpbmZvcm1hY2nDs24gYSBjYWRlbmEgZGUgY2FyYWN0ZXJlcy4KTGEgY2xhc2UgZXN0dWRpYW50ZSBkZXJpdmFkYSBkZSBwZXJzb25hIGNvbnRpZW5lCmxhIGluc3RpdHVjacOzbiwgZWwgbm9tYnJlIGRlbCBncmFkbyB5CmVsIG7Dum1lcm8gZGUgY3Vyc28gKDEgYSA0KS4KVG9kYSBlc3RhIGluZm9ybWFjacOzbiB0YW1iacOpbiBzZSBwdWJsaWNhCmNvbW8gcHJvcGllZGFkZXMgZGUgc29sbyBsZWN0dXJhIHkgdGFtYmnDqW4gb2ZyZWNlCnVuIG3DqXRvZG8gc3RyIHF1ZSBjb252aWVydGUgdG9kYSBsYSBpbmZvcm1hY2nDs24KYSBjYWRlbmEgZGUgY2FyYWN0ZXJlcy4KRmluYWxtZW50ZSwgbGEgY2xhc2UgUGVyc29uYVJlcG8gY29udGllbmUKdW5hIGxpc3RhIGRlIHBlcnNvbmFzLCB1biBtw6l0b2RvIHN0cgpxdWUgZGV2dWVsdmUgdG9kYSBsYSBpbmZvcm1hY2nDs24gZGUKdG9kYXMgbGFzIHBlcnNvbmFzICh1bmEgcG9yIGzDrW5lYSksCnkgdW5hIHByb3BpZWRhZCBkZSBzb2xvIGxlY3R1cmEgcGVyc29uYXMKcXVlIGRldnVlbHZlIHVuYSBsaXN0YSBkZSBwZXJzb25hcy4KQWRlbcOhcywgZWwgbcOpdG9kbyBidXNjYSBhZG1pdGUgdW5hIGxhbWJkYQpxdWUgcGVybWl0ZSBlamVjdXRhciB1biBmaWx0cmFkbwpkZSBsYXMgcGVyc29uYXMgYWxtYWNlbmFkYXMuCiIiIgoKIyBCbGFja2JveAoKCmZyb20gZGF0ZXRpbWUgaW1wb3J0IGRhdGV0aW1lCgoKY2xhc3MgUGVyc29uYToKICAgIGRlZiBfX2luaXRfXyhzZWxmLCBub21icmUsIGFwZWxsaWRvcywgZW1haWwsIGZlY2hhX25hY2ltaWVudG8pOgogICAgICAgIHNlbGYuX25vbWJyZSA9IG5vbWJyZQogICAgICAgIHNlbGYuX2FwZWxsaWRvcyA9IGFwZWxsaWRvcwogICAgICAgIHNlbGYuX2VtYWlsID0gZW1haWwKICAgICAgICBzZWxmLl9mZWNoYV9uYWNpbWllbnRvID0gZmVjaGFfbmFjaW1pZW50bwoKCiAgICBAcHJvcGVydHkKICAgIGRlZiBub21icmUoc2VsZik6CiAgICAgICAgcmV0dXJuIHNlbGYuX25vbWJyZQoKCiAgICBAcHJvcGVydHkKICAgIGRlZiBhcGVsbGlkb3Moc2VsZik6CiAgICAgICAgcmV0dXJuIHNlbGYuX2FwZWxsaWRvcwoKCiAgICBAcHJvcGVydHkKICAgIGRlZiBlbWFpbChzZWxmKToKICAgICAgICByZXR1cm4gc2VsZi5fZW1haWwKCgogICAgQHByb3BlcnR5CiAgICBkZWYgZmVjaGFfbmFjaW1pZW50byhzZWxmKToKICAgICAgICByZXR1cm4gc2VsZi5fZmVjaGFfbmFjaW1pZW50bwoKCiAgICBkZWYgX19zdHJfXyhzZWxmKToKICAgICAgICByZXR1cm4gZiJ7c2VsZi5ub21icmV9IHtzZWxmLmFwZWxsaWRvc30gLSB7c2VsZi5lbWFpbH0gLSB7c2VsZi5mZWNoYV9uYWNpbWllbnRvLnN0cmZ0aW1lKCclZC8lbS8lWScpfSIKCgpjbGFzcyBFbXBsZWFkbyhQZXJzb25hKToKICAgIGRlZiBfX2luaXRfXyhzZWxmLCBub21icmUsIGFwZWxsaWRvcywgZW1haWwsIGZlY2hhX25hY2ltaWVudG8sIGVtcHJlc2EpOgogICAgICAgIHN1cGVyKCkuX19pbml0X18obm9tYnJlLCBhcGVsbGlkb3MsIGVtYWlsLCBmZWNoYV9uYWNpbWllbnRvKQogICAgICAgIHNlbGYuX2VtcHJlc2EgPSBlbXByZXNhCgogICAgQHByb3BlcnR5CiAgICBkZWYgZW1wcmVzYShzZWxmKToKICAgICAgICByZXR1cm4gc2VsZi5fZW1wcmVzYQoKICAgIGRlZiBfX3N0cl9fKHNlbGYpOgogICAgICAgIHJldHVybiBmIntzdXBlcigpLl9fc3RyX18oKX0gLSB7c2VsZi5lbXByZXNhfSIKCgpjbGFzcyBFc3R1ZGlhbnRlKFBlcnNvbmEpOgogICAgZGVmIF9faW5pdF9fKHNlbGYsIG5vbWJyZSwgYXBlbGxpZG9zLCBlbWFpbCwgZmVjaGFfbmFjaW1pZW50bywgaW5zdGl0dWNpb24sIG5vbWJyZV9ncmFkbywgY3Vyc28pOgogICAgICAgIHN1cGVyKCkuX19pbml0X18obm9tYnJlLCBhcGVsbGlkb3MsIGVtYWlsLCBmZWNoYV9uYWNpbWllbnRvKQogICAgICAgIHNlbGYuX2luc3RpdHVjaW9uID0gaW5zdGl0dWNpb24KICAgICAgICBzZWxmLl9ub21icmVfZ3JhZG8gPSBub21icmVfZ3JhZG8KICAgICAgICBzZWxmLl9jdXJzbyA9IGN1cnNvCgoKICAgIEBwcm9wZXJ0eQogICAgZGVmIGluc3RpdHVjaW9uKHNlbGYpOgogICAgICAgIHJldHVybiBzZWxmLl9pbnN0aXR1Y2lvbgoKICAgIEBwcm9wZXJ0eQogICAgZGVmIG5vbWJyZV9ncmFkbyhzZWxmKToKICAgICAgICByZXR1cm4gc2VsZi5fbm9tYnJlX2dyYWRvCgogICAgQHByb3BlcnR5CiAgICBkZWYgY3Vyc28oc2VsZik6CiAgICAgICAgcmV0dXJuIHNlbGYuX2N1cnNvCgogICAgZGVmIF9fc3RyX18oc2VsZik6CiAgICAgICAgcmV0dXJuIGYie3N1cGVyKCkuX19zdHJfXygpfSAtIHtzZWxmLmluc3RpdHVjaW9ufSAtIHtzZWxmLm5vbWJyZV9ncmFkb30gLSBDdXJzbyB7c2VsZi5jdXJzb30iCgoKY2xhc3MgUGVyc29uYVJlcG86CiAgICBkZWYgX19pbml0X18oc2VsZik6CiAgICAgICAgc2VsZi5fcGVyc29uYXMgPSBbXQoKICAgIEBwcm9wZXJ0eQogICAgZGVmIHBlcnNvbmFzKHNlbGYpOgogICAgICAgIHJldHVybiBzZWxmLl9wZXJzb25hcwoKICAgIGRlZiBidXNjYXIoc2VsZiwgZmlsdHJvKToKICAgICAgICByZXR1cm4gW3AgZm9yIHAgaW4gc2VsZi5fcGVyc29uYXMgaWYgZmlsdHJvKHApXQoKICAgIGRlZiBfX3N0cl9fKHNlbGYpOgogICAgICAgICMgTW9kaWZpY2FkbyBzZWxmLl9wZXJzb25hIHBvciBzZWxmLl9wZXJzb25hcwogICAgICAgIHJldHVybiAiXG4iLmpvaW4oc3RyKHApIGZvciBwIGluIHNlbGYuX3BlcnNvbmFzKQoKCiAgICBkZWYgYWdyZWdhcl9wZXJzb25hKHNlbGYsIHBlcnNvbmEpOgogICAgICAgIHNlbGYuX3BlcnNvbmFzLmFwcGVuZChwZXJzb25hKQoKCnJlcG8gPSBQZXJzb25hUmVwbygpCnAxID0gUGVyc29uYSgiSnVhbiIsICJQw6lyZXoiLCAianVhbkBleGFtcGxlLmNvbSIsIGRhdGV0aW1lKDE5OTAsIDEsIDEpKQpwMiA9IEVtcGxlYWRvKCJNYXLDrWEiLCAiR29uesOhbGV6IiwgIm1hcmlhQGV4YW1wbGUuY29tIiwgZGF0ZXRpbWUoMTk5MiwgMiwgMiksICJFbXByZXNhIFhZWiIpCnAzID0gRXN0dWRpYW50ZSgiUGVkcm8iLCAiUm9kcsOtZ3VleiIsICJwZWRyb0BleGFtcGxlLmNvbSIsIGRhdGV0aW1lKDE5OTUsIDMsIDMpLCAiVW5pdmVyc2lkYWQgQUJDIiwgIkluZ2VuaWVyw61hIiwgMikKCnJlcG8uYWdyZWdhcl9wZXJzb25hKHAxKQpyZXBvLmFncmVnYXJfcGVyc29uYShwMikKcmVwby5hZ3JlZ2FyX3BlcnNvbmEocDMpCgpwcmludChyZXBvKQoKIyBCdXNjYXIgcGVyc29uYXMgcXVlIHRpZW5lbiBtw6FzIGRlIDI1IGHDsW9zCm1heW9yZXNfZGVfMjUgPSByZXBvLmJ1c2NhcihsYW1iZGEgcDogKGRhdGV0aW1lLm5vdygpIC0gcC5mZWNoYV9uYWNpbWllbnRvKS5kYXlzIC8vIDM2NSA+IDI1KQpwcmludCgiTWF5b3JlcyBkZSAyNSBhw7FvczoiKQpmb3IgcCBpbiBtYXlvcmVzX2RlXzI1OgogICAgcHJpbnQocCkK