Python Ile Mail - Metin Eklentileri (Text Attachment)
Python script icinden otomatik email gondermek ve mesaja txt, csv dosyasi eklemek icin alttaki mail.py adli script kullanilabilir. Script SMTP servisi olarak localhost, yani yerel makinada bir SMTP servisi oldugunu farz ediyor. Bu servisin yeri degistirilebilir, mesela bir GMail hesabi ve SMTP servisi de kullanilabilir.
import smtplib, os
from email.MIMEMultipart import MIMEMultipart
from email.MIMEBase import MIMEBase
from email.MIMEText import MIMEText
from email.Utils import COMMASPACE, formatdate
from email import Encoders
def send_mail(send_from, send_to, subject, text, files=[], server="localhost"):
assert type(send_to)==list
assert type(files)==list
msg = MIMEMultipart()
msg['From'] = send_from
msg['To'] = COMMASPACE.join(send_to)
msg['Date'] = formatdate(localtime=True)
msg['Subject'] = subject
msg.attach( MIMEText(text) )
for f in files:
part = MIMEBase('application', "octet-stream")
part.set_payload( open(f,"rb").read() )
Encoders.encode_base64(part)
part.add_header('Content-Disposition', 'attachment; filename="%s"' % os.path.basename(f))
msg.attach(part) smtp = smtplib.SMTP(server)
smtp.sendmail(send_from, send_to, msg.as_string())
smtp.close()
Kullanimi
import datetime
import mail
import sys
start = datetime.datetime.now()
date = datetime.datetime.today().strftime('%Y-%m-%d')
mail.send_mail('nereden@filan.com',
['nereye@falan.com'],
'%s tarihinde gonderilen mesaj' % date,
'Mesaj basligi .. ',
['dosya1.csv','dosya2,csv'])
Yukarı