Compare commits

...

3 commits

Author SHA1 Message Date
02b76b5755 Update readme 2022-10-09 19:14:16 +02:00
0bb4a1d06c Parameterize everything 2022-10-09 19:14:07 +02:00
f6abda8772 Add ignores 2022-10-09 19:12:45 +02:00
4 changed files with 21 additions and 6 deletions

5
.gitignore vendored Normal file
View file

@ -0,0 +1,5 @@
vars.py
*.csv
message.html
.DS_Store
*.pyc

View file

@ -4,8 +4,8 @@ Easily send mails via SMTP and python
## Setup
1. Copy `vars.py.example` to `vars.py`
2. Setup `vars.py` with your credentials
3. Adapt `message.txt` and import `contacts.csv`
2. Setup `vars.py` with your credentials and config
3. Adapt `message.htmt` and save your contact list to `contacts.csv`
## Usage
```python mail.py```

11
mail.py
View file

@ -1,4 +1,5 @@
import smtplib
import time
from string import Template
@ -32,7 +33,7 @@ def read_template(filename):
def main():
contacts = get_contacts('contacts.csv')
message_template = read_template('message.txt')
message_template = read_template('message.html')
# set up the SMTP server
s = smtplib.SMTP(HOST, PORT)
@ -41,6 +42,7 @@ def main():
# For each contact, send the email:
for i in contacts.index:
print(f"Sending email {i+1}\n")
msg = MIMEMultipart() # create a message
# add in the actual person name to the message template
@ -48,11 +50,11 @@ def main():
message = message_template.substitute(contact_dict)
# Prints out the message body for our sake
print(message)
print(f"{message}\n")
# setup the parameters of the message
msg['From'] = MY_ADDRESS
msg['To'] = contacts["email"][i]
msg['To'] = contacts[MAIL_COLUMN][i]
msg['Subject'] = SUBJECT
# add in the message body
@ -62,6 +64,9 @@ def main():
s.send_message(msg)
del msg
if (i + 1) % WAIT_EVERY == 0:
time.sleep(DELAY_SEC)
# Terminate the SMTP session and close the connection
s.quit()

View file

@ -1,5 +1,10 @@
SUBJECT = ''
EMAIL_COLUMN = ''
MY_ADDRESS = 'example@domain.tld'
PASSWORD = 'p4ssw0rd'
HOST = 'mail.domain.tld'
PORT = 587
SUBJECT = ''
WAIT_EVERY = 5
DELAY_SEC = 0