最近经常需要出一些临时性的报表,于是就用python 的smtplib 和email 两模块写了个小程序,当数据处理完后通过邮箱把报表文件从服务器上发送出来!
程序名称:sendMail_func.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import os
import sys
import time
import smtplib
from email import encoders
from email.mime.text import MIMEText
from email.mime.base import MIMEBase
from email.mime.multipart import MIMEMultipart
def send_mail(sub,content,mail_to,fileList):
mail_host = 'smtp.163.com'
mail_user = '****@163.com'
mail_pass = '******'
mail_to_list = mail_to.split( ',' )
msg = MIMEMultipart()
#msg=MIMEText(content,_charset='utf-8')
msg[ 'Subject' ] = sub
msg[ 'From' ] = mail_user
msg[ 'To' ] = ";" .join(mail_to_list)
msg.attach(MIMEText(content,_charset = 'utf-8' ))
files = fileList.split( ',' )
for f in files:
part = MIMEBase( 'application' , 'octet-stream' ) #'octet-stream': binary data
part.set_payload( open (f, 'rb' ).read())
encoders.encode_base64(part)
part.add_header( 'Content-Disposition' , 'attachment; filename="%s"' % os.path.basename(f).encode( 'utf-8' ))
msg.attach(part)
try :
s = smtplib.SMTP()
s.connect(mail_host)
s.login(mail_user,mail_pass)
s.sendmail(mail_user,mail_to_list,msg.as_string())
s.close()
return True
except Exception, e:
print str (e)
return False
if __name__ = = "__main__" :
if len (sys.argv) = = 5 :
send_mail(sys.argv[ 1 ],sys.argv[ 2 ],sys.argv[ 3 ],sys.argv[ 4 ])
else :
print ''
print '*************************************************'
print ' 如: python sendMail_func.py 邮件测试 邮件内容 abc@126.com,def@163.com,123456789@qq.com 1.xlsx,2.xlsx'
print '*************************************************'
print ''
exit
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/chx3515/article/details/44061785