From f13485ec946ac56687790b2f1c2801d126c603b0 Mon Sep 17 00:00:00 2001 From: aysegulyildizz <139223718+aysegulyildizz@users.noreply.github.com> Date: Tue, 23 Dec 2025 10:55:19 +0300 Subject: [PATCH] Create Emails class for email validation and uniqueness Implement Emails class to validate and store unique email addresses. --- Week03/emails_aysegul_yildiz.py | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 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..fb117099 --- /dev/null +++ b/Week03/emails_aysegul_yildiz.py @@ -0,0 +1,29 @@ +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)