From 19cf38aeca572243aa5c20b4722d3a248a6f4669 Mon Sep 17 00:00:00 2001 From: aysegulyildizz <139223718+aysegulyildizz@users.noreply.github.com> Date: Tue, 23 Dec 2025 11:48:51 +0300 Subject: [PATCH] Add Emails class for email validation and uniqueness --- Week03/emails_aysegul_yildiz.py | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 Week03/emails_aysegul_yildiz.py diff --git a/Week03/emails_aysegul_yildiz.py b/Week03/emails_aysegul_yildiz.py new file mode 100644 index 00000000..ab8c7fad --- /dev/null +++ b/Week03/emails_aysegul_yildiz.py @@ -0,0 +1,30 @@ +import re + + +class Emails(list): + def __init__(self, emails): + self.validate(emails) + + unique_emails = list(set(emails)) + super().__init__(unique_emails) + self.data = unique_emails + + def validate(self, emails): + if not isinstance(emails, list): + raise ValueError + + email_regex = re.compile( + r"^[a-zA-Z0-9_.+-]+@[a-zA-Z0-9-]+\.[a-zA-Z0-9-.]+$" + ) + + for email in emails: + if not isinstance(email, str): + raise ValueError + if not email_regex.match(email): + raise ValueError + + def __repr__(self): + return f"Emails({list(self)})" + + def __str__(self): + return "\n".join(self)