python發(fā)送郵件腳本
更新時(shí)間:2018年05月22日 16:57:07 作者:RangeYan
這篇文章主要為大家詳細(xì)介紹了發(fā)送郵件python腳本,支持多個(gè)附件,中文,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本文實(shí)例為大家分享了python發(fā)送郵件的具體代碼,供大家參考,具體內(nèi)容如下
#!/usr/bin/env python # -*- coding: utf-8 -*- import smtplib import sys from email.mime.text import MIMEText import linecache import email import os ##################### # set email service host,user,pass word,postfix mail_host="smtp.exmail.qq.com" mail_user="username" mail_pass="password" mail_postfix="qq.com" ###################### def transfer_utf8_to_gb2312(file_name): f=open(file_name) s=f.read() f.close() u=s.decode("utf-8") s=u.encode("gb2312") f=open(file_name,"w"); f.write(s) def send_mail(to_list,sub,content_file_name): me=mail_user+"<"+mail_user+"@"+mail_postfix+">" msg = email.MIMEMultipart.MIMEMultipart() content = open(content_file_name.encode("utf-8"), 'rb') content_msg = MIMEText(content.read(),"plain","utf-8") msg.attach(content_msg) msg['Subject'] = sub msg['From'] = me msg['To'] = ";".join(to_list) try: s = smtplib.SMTP() s.connect(mail_host) s.login(mail_user+"@"+mail_postfix,mail_pass) s.sendmail(me, to_list, msg.as_string()) s.close() return True except Exception, e: print "error:",str(e) return False def send_mail_with_attachment(to_list,sub,content_file_name,attachment_file_name): me=mail_user+"<"+mail_user+"@"+mail_postfix+">" msg = email.MIMEMultipart.MIMEMultipart() content = open(content_file_name.encode("utf-8"), 'rb') content_msg = MIMEText(content.read(),"plain","utf-8") msg.attach(content_msg) for tmp_attachment_file_name in attachment_file_name.split(","): contype = 'application/octet-stream' maintype, subtype = contype.split('/', 1) file_data = open(tmp_attachment_file_name.encode("utf-8"), 'rb') file_msg = email.MIMEBase.MIMEBase(maintype, subtype) file_msg.set_payload(file_data.read()) file_data.close( ) email.Encoders.encode_base64(file_msg) basename = os.path.basename(tmp_attachment_file_name) file_msg.add_header('Content-Disposition', 'attachment', filename = basename.encode("utf-8")) msg.attach(file_msg) msg['Subject'] = sub msg['From'] = me msg['To'] = ";".join(to_list) try: s = smtplib.SMTP() s.connect(mail_host) s.login(mail_user+"@"+mail_postfix,mail_pass) s.sendmail(me, to_list, msg.as_string()) s.close() return True except Exception, e: print "error:",str(e) return False def print_usage(): print "Usage: " print " %s email_send_list(xxx@163.com,xxx@qq.com,...) subject content_file_name" % (sys.argv[0]) print " %s email_send_list(xxx@163.com,xxx@qq.com,...) subject content_file_name attachment_file_name(file_name1,file_name2,...) if_transform_attachment_to_gb2312(yes or not)" % (sys.argv[0]) ######Start from here######### if __name__ == '__main__': reload(sys) sys.setdefaultencoding('utf8') if len(sys.argv) == 6: send_list = sys.argv[1].split(",") subject = unicode(sys.argv[2],"utf-8") content_file_name = unicode(sys.argv[3],"utf-8") attachment_file_name = unicode(sys.argv[4],"utf-8") if(sys.argv[5] == "yes"): transfer_utf8_to_gb2312(attachment_file_name.decode("utf-8")) elif(sys.argv[5] == "not"): pass else: print_usage() if send_mail_with_attachment(send_list,subject,content_file_name,attachment_file_name): print "Send email success!" else: print "Send email fail!" sys.exit(1) elif len(sys.argv) == 4: send_list = sys.argv[1].split(",") subject = unicode(sys.argv[2],"utf-8") content_file_name = unicode(sys.argv[3],"utf-8") if send_mail(send_list,subject,content_file_name): print "Send email success!" else: print "Send email fail!" sys.exit(1) else: print_usage()
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- python實(shí)現(xiàn)自動(dòng)發(fā)送郵件
- python通過微信發(fā)送郵件實(shí)現(xiàn)電腦關(guān)機(jī)
- python3實(shí)現(xiàn)SMTP發(fā)送郵件詳細(xì)教程
- 使用python 3實(shí)現(xiàn)發(fā)送郵件功能
- python發(fā)送郵件的實(shí)例代碼(支持html、圖片、附件)
- python中使用smtplib和email模塊發(fā)送郵件實(shí)例
- Python實(shí)現(xiàn)SMTP發(fā)送郵件詳細(xì)教程
- Python實(shí)現(xiàn)給qq郵箱發(fā)送郵件的方法
- python同時(shí)給兩個(gè)收件人發(fā)送郵件的方法
- python自動(dòng)發(fā)送郵件腳本
相關(guān)文章
Python如何按單元格讀取復(fù)雜電子表格(Excel)的數(shù)據(jù)
這篇文章主要介紹了Python如何按單元格讀取復(fù)雜電子表格(Excel)的數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06Python獲取運(yùn)行目錄與當(dāng)前腳本目錄的方法
這篇文章主要介紹了Python獲取運(yùn)行目錄與當(dāng)前腳本目錄的方法,涉及Python目錄操作與系統(tǒng)相關(guān)變量的獲取技巧,需要的朋友可以參考下2015-06-06Python中五種實(shí)現(xiàn)字符串反轉(zhuǎn)的方法
這篇文章主要介紹了Python中五種實(shí)現(xiàn)字符串反轉(zhuǎn)的方法,編寫一個(gè)函數(shù),其作用是將輸入的字符串反轉(zhuǎn)過來。下面文章關(guān)于其詳細(xì)介紹,需要的小伙伴可以參考一下2022-05-05python使用selenium實(shí)現(xiàn)批量文件下載
這篇文章主要介紹了python使用selenium實(shí)現(xiàn)批量文件下載,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03解決Python獲取字典dict中不存在的值時(shí)出錯(cuò)問題
今天小編就為大家分享一篇解決Python獲取字典dict中不存在的值時(shí)出錯(cuò)問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10