You can clone with
# Example for sending an email with an attached image using smtplib
# IMPORTANT: You need to enter your email login in the main() function.
# The example is prepared for GMail, but other providers
# should be possible by changing the mail server.
from email.mime.base import MIMEBase
from email.mime.multipart import MIMEMultipart
from email import encoders
from io import BytesIO
bytes = BytesIO()
msg = MIMEBase('image', 'jpeg')
### CHANGE THESE VALUES:
to = 'email@example.com'
subject = 'Image from Pythonista'
gmail_user = 'YOUR_GMAIL_ADDRESS'
gmail_pwd = 'YOUR_PASSWORD'
#Load a sample image, modify as needed:
image = Image.open('Test_Lenna')
smtpserver = smtplib.SMTP("smtp.gmail.com", 587)
print 'Preparing message...'
outer = MIMEMultipart()
outer['Subject'] = subject
outer['To'] = to
outer['From'] = gmail_user
outer.preamble = 'You will not see this in a MIME-aware email reader.\n'
attachment = get_attachment(image)
composed = outer.as_string()
smtpserver.sendmail(gmail_user, to, composed)
if __name__ == '__main__':
Hello Ole. Great script. My question is how to add more types of image formats such as png, etc?
@pawelratajczak Basically, you would have to set the format to 'PNG' in line 16, modify the mime type to 'image', 'png' in line 17, and change the filename to something like image.png in line 21.
Basically, you would just have to replace jpeg with png in lines 16 to 21 (while preserving the capitalization).
I've tried using this but can't get it working with iCloud email. I've tried switching to SMTP_SSL('smtp.mail.me.com', 587) as Apple says SSL is required with no luck.
after i modify the script, I am enjoying it with a shortcut on my iphone. How do I share it with my collegues who don't have pythonista? Anyway I can export the script so that my collegues can use it without pythonista?
Great work! I am using it to email post to Flickr. Thanks!
How about emailing a .csv file created by another pythonista script? The files reside in the same directory as the python scripts. How can that be done?
I just started working on doing a csv file right. I'll post when I get it working. Meanwhile I think the key is to change the get_attachment function to use MIMEText instead of MIMEBase to fill the msg variable. MIMEText is used to create a text file attachment.
It needs to read the entire file into a variable and pass it as the argument to MIMEText. Something like:
fp = open('file.csv', 'rb')
# Create a text/plain message
msg = MIMEText(fp.read())
Sorry. There are several typos in that but I hope they are obvious. I'll post a working example when I get one working.
Close but no cigar. MIMEText sent the text file as the email message instead of as an attachment. That's not what O wanted and probably not what you (rabdeb) wanted. More research clearly needed. ;-)