So I have tried multiple method in attaching a file (in particular a CSV file) to an email in python and sending. I have had text email working correctly and I indeed receive a CSV file, just an empty one. I am currently sending my attachments like so:
ctype, encoding = mimetypes.guess_type("results.csv")
if ctype is None or encoding is not None:
ctype = "application/octet-stream"
maintype, subtype = ctype.split("/", 1)
# organizing receivers
receiver = receivers.split(',')
# creating subject
subject = 'BLAH BLAH'
timestamp = time.strftime("%m/%d/%Y:%H:%M:%S")
subject += str(timestamp)
# form email
msg = MIMEMultipart()
msg['From'] = sender
msg['To'] = " ".join(receivers)
msg['Subject'] = subject
msg['Message-Id'] = make_msgid()
msg['Date'] = formatdate(localtime=True)
msg.attach(MIMEText(msgstr, 'plain'))
if maintype == "text":
fp = open("results.csv")
attachment = MIMEText(fp.read(), _subtype=subtype)
fp.close()
else:
fp = open('results.csv', "rb")
attachment = MIMEBase(maintype, subtype)
attachment.set_payload(fp.read())
fp.close()
encoders.encode_base64(attachment)
attachment.add_header("Content-Disposition", "attachment", filename='results.csv')
msg.attach(attachment)
try:
smtpobj = smtplib.SMTP('smtp.gmail.com:587')
smtpobj.ehlo()
smtpobj.starttls()
smtpobj.ehlo()
smtpobj.login(username, password)
smtpobj.sendmail(sender, receiver, msg.as_string())
smtpobj.quit()
except smtplib.SMTPException:
print 'Error: unable to send mail'
This is similar to the answer here: python can't send attachment files through email I have also tried simpler approaches similar to: How to send email attachments with Python https://docs.python.org/2/library/email.html
and others, but with no success. How can I send a complete attachment?