一个python的邮件发送脚本,自动,定时,可以附件发送,抄送,附有说明文件
#!/bin/env python
# -*- coding: utf-8 -*- import datetime
import smtplib
import os,sys
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.base import MIMEBase
from optparse import OptionParser EMAILHOME=sys.path[0]
#sender name and password
sendername=""
senderpass=""
#list of all receiver (include cc-receiver)
receiverlist=[]
receivertmplist=[]
receivercctmplist=[] #get the username and pasword
#no try catch here
def getUserAndPass(senderfile):
upf=open(senderfile)
username=upf.readline()
password=upf.readline()
upf.close()
return (username.strip(os.linesep),password.strip(os.linesep)) #get the receiver list
#return the list with no ''
def getReceiverList(filename):
lif=open(filename)
li=lif.readlines()
lif.close()
for x in range(len(li)):
li[x]=li[x].strip().strip(os.linesep)
while '' in li:
li.remove('')
return (li) #get content of the mail
def getContent(filename):
contenttmp=''
if os.path.exists(filename):
contentf=open(filename)
contenttmp=contentf.read()
contentf.close()
return contenttmp #parameters process
parser = OptionParser() parser.add_option('-s', '--sender', dest='sender',
help='file for sender of the mail', default=None)
parser.add_option('-r', '--receiver', dest='receiver',
help='list file for receivers of the mail',default=None)
parser.add_option('-p', '--cc', dest='cc',
help='list file for receivers of carbon copy', default=None)
parser.add_option('-t', '--title', dest='title',
help='title of the email,string', default='Auto email')
parser.add_option('-c', '--content', dest='content',
help='content of the mail,must be a file',default=None)
parser.add_option('-a', '--attach', dest='attach',
help='attachment of the file',default=None)
parser.add_option('-n', '--nameattach', dest='nameattach',
help='name for attachment of the file',default=None)
parser.add_option('-l', '--server', dest='server',
help='log in to the server',default='smtp.163.com')
parser.add_option('-i', '--info', dest='info',
help='information of the content,string,but not file',default='Auto email')
parser.add_option('-f', '--form', dest='form',
help='form of the content,html or plain',default='plain') (options, args) = parser.parse_args() #get sender infor
if not options.sender:
if os.path.exists(EMAILHOME+r'/sender.list'):
(sendername,senderpass)=getUserAndPass(EMAILHOME+r'/sender.list')
if sendername.strip()=="" or senderpass.strip()=="":
print ("no sender!")
exit(0)
else:
print ("no sender!")
exit(0)
else:
if os.path.exists(options.sender):
(sendername,senderpass)=getUserAndPass(EMAILHOME+r'/sender.list')
if sendername.strip()=="" or senderpass.strip()=="":
print ("no sender!")
exit(0)
else:
print ("the file for sender list does not exists!")
exit(0) #get list of all receiver
if not options.receiver:
if os.path.exists(EMAILHOME+r'/receiver.list') or os.path.exists(EMAILHOME+r'/receivercc.list'):
if os.path.exists(EMAILHOME+r'/receiver.list'):
receivertmplist= getReceiverList(EMAILHOME+r'/receiver.list')
if os.path.exists(EMAILHOME+r'/receivercc.list'):
receivercctmplist= getReceiverList(EMAILHOME+r'/receivercc.list')
receiverlist=receivertmplist+receivercctmplist
if len(receiverlist)==0:
print ("no receiver!")
exit(0)
else:
print ("no receiver list file!")
exit(0)
else:
if os.path.exists(options.receiver) or os.path.exists(options.cc):
if os.path.exists(options.receiver):
receivertmplist= getReceiverList(options.receiver)
if os.path.exists(options.cc):
receivercctmplist= getReceiverList(options.cc)
receiverlist=receivertmplist+receivercctmplist
if len(receiverlist):
print ("no receiver from the list file!")
exit(0)
else:
print ("receiver list file does not exist!")
exit(0) if options.attach and not options.nameattach:
print ("give a name to the attachment!")
exit(0) #make a mail
mailall=MIMEMultipart() #content of the mail
if options.content:
mailcontent =getContent(options.content)
mailall.attach(MIMEText(mailcontent,options.form,'utf-8'))
elif options.info:
mailcontent = str(options.info)
mailall.attach(MIMEText(mailcontent,options.form,'utf-8')) #attachment of the mail
if options.attach:
mailattach =getContent(options.attach)
if mailattach !='':
contype = 'application/octet-stream'
maintype,subtype=contype.split('/',1)
attfile=MIMEBase(maintype,subtype)
attfile.set_payload(mailattach)
attfile.add_header('Content-Disposition','attachment',options.nameattach)
print ("attach file prepared!")
mailall.attach(attfile) #title,sender,receiver,cc-receiver,
mailall['Subject']=options.title
mailall['From']=sendername
mailall['To']=str(receivertmplist)
if len(receivercctmplist) !=0:
mailall['CC']=str(receivercctmplist) #get the text of mailall
fullmailtext=mailall.as_string()
print ("prepare fullmailtext ok.")
mailconnect = smtplib.SMTP(options.server)
try:
mailconnect.login(sendername,senderpass)
except Exception as e:
print ("error when connect the smtpserver with the given username and password !")
print (e)
exit(0) print ("connect ok!") try:
mailconnect.sendmail(sendername, receiverlist, fullmailtext)
except Exception as e:
print ("error while sending the email!")
finally:
mailconnect.quit() print ('email to '+str(receiverlist)+' over.') print ('***'*80)
说明:
#mail.py使用方法:
1,本脚本同目录下文件介绍:
sender.list:邮件发送者邮箱和密码,第一行账号(如example@example.com),第二行密码(必须项,不能为空)
receiver.list:邮件接收者列表,每行一个收件人(如example@example.com)
receivercc.list:邮件抄送者列表,每行一个收件人(如example@example.com)
调用方法举例1:
把发件人和收件人信息(sender.list和receiver.list)填好后,在mail.py所在目录执行
python mail.py -s sender.list -r receiver.list
2,其它帮助信息获得方法:
在mail.py所在目录执行:python mail.py -h
显示:
Options:
-h, --help show this help message and exit
-s SENDER, --sender=SENDER //配置本脚本发件人信息存放的文件的路径 如 /tmp/tmp/list.list
file for sender of the mail
-r RECEIVER, --receiver=RECEIVER //配置本脚本收件人列表存放的文件的路径 如 /tmp/tmp/list.list
list file for receivers of the mail
-p CC, --cc=CC list file for receivers of carbon copy //配置抄送收件人列表存放的文件的路径 如 /tmp/tmp/list.list
-t TITLE, --title=TITLE //配置邮件的标题,字符串(不能有空格)
title of the email,string
-c CONTENT, --content=CONTENT //配置邮件的内容,文件路径(和-i冲突时,-i参数无效)
content of the mail,must be a file
-a ATTACH, --attach=ATTACH //配置邮件的附件,文件路径(有附件时,必须配置-n参数)
attachment of the file
-n NAMEATTACH, --nameattach=NAMEATTACH //配置邮件的附件名称,字符串(不能有空格)(有附件时,必须配置本参数)
name for attachment of the file
-l SERVER, --server=SERVER //配置邮件的服务器,默认是smtp.163.com
log in to the server
-i INFO, --info=INFO information of the content,string,but not file //配置邮件的内容,字符串(不能有空格)(和-c冲突时,本参数无效)
-f FORM, --form=FORM form of the content,html or plain //配置邮件的内容的类型,默认是plain
调用方法举例2:
在mail.py所在目录执行:
python mail.py -s /root/tmp/sender.list -r /root/tmp/receiver.list -p /root/tmp/receivercc.list -t test_the_py -c /root/tmp/content.log -a /root/tmp/attch.log -n attachname1.log
将会把/root/tmp/content.log作为文件内容,
把/root/tmp/attch.log作为附件,
把attachname1.log作为附件名称,
把test_the_py作为邮件标题的邮件;
从/root/tmp/sender.list文件里的发件人,
发送到/root/tmp/receiver.list和/root/tmp/receivercc.list文件里的收件人列表。
一个python的邮件发送脚本,自动,定时,可以附件发送,抄送,附有说明文件的更多相关文章
- python实现邮件发送完整代码(带附件发送方式)
实例一:利用SMTP与EMAIL实现邮件发送,带附件(完整代码) __author__ = 'Administrator'#coding=gb2312 from email.Header import ...
- CentOS/Linux内存占用大,用Shell脚本自动定时清除/释放内存
CentOS/Linux内存占用大,用Shell脚本自动定时清除/释放内存来自:互联网 时间:2020-03-22 阅读:114以下情况可能造成Linux内存占用过高服务配置存在直接分配错误,或隐性分 ...
- Git学习-->如何通过Shell脚本自动定时将Gitlab备份文件复制到远程服务器?
一.背景 在我之前的博客 git学习--> Gitlab如何进行备份恢复与迁移? (地址:http://blog.csdn.net/ouyang_peng/article/details/770 ...
- ROS 5.x自动定时备份并发送到邮箱(实用)
博主使用ROS已经有很长一段时间了,但经常会忘记备份配置与数据库,加上ROS本身自带的User-Man数据库并不是非常稳定,1年中总会出现1-2次数据丢失的情况.所以费了一定功夫才找到真正可用自动备份 ...
- 如何手动写一个Python脚本自动爬取Bilibili小视频
如何手动写一个Python脚本自动爬取Bilibili小视频 国庆结束之余,某个不务正业的码农不好好干活,在B站瞎逛着,毕竟国庆嘛,还让不让人休息了诶-- 我身边的很多小伙伴们在朋友圈里面晒着出去游玩 ...
- centos 7 keepalived故障邮件通知实战(附Python邮件发送脚本)
centos 7 keepalived故障邮件通知实战(附Python邮件发送脚本) ##################### sendmail.py begin ######## ...
- python 邮件发送 脚本
import smtplib from email.header import Header from email.mime.text import MIMEText from_addr = 'XXX ...
- 用Node+wechaty写一个爬虫脚本每天定时给女(男)朋友发微信暖心话
wechatBot 微信每日说,每日自动发送微信消息给你心爱的人 项目介绍 灵感来源 在掘金看到了一篇<用Node + EJS写一个爬虫脚本每天定时女朋友发一封暖心邮件>后, 在评论区偶然 ...
- python SMTP邮件发送(转载)
Python SMTP发送邮件 SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式. py ...
随机推荐
- Xamarin for Visual Studio V3.11.431 于 2015.4.3-2015.4.17 最新发布(Win & Mac)
Beta Release: April 3 edited April 17 in Visual Studio Released versions: Windows Xamarin.VisualStud ...
- python 数据类型---列表使用之三
1. 判断列表中是否存在一个元素: "in" 的使用 list = ['Frank', 99, 'is',78, 7,3,4,'smart'] print(99 in list) ...
- mysql substring函数截取值后赋给一个declare变量
今天写的一个mysql存储过程涉及到对一个传入参数的字符串截取,然后需要判断截取字符串进行一系列操作,最开始用select subtring() into 这样的方法将截取值赋于declare变量直 ...
- 9.2.1 .net framework下的MVC 控件的封装(上)
在写.net core下mvc控件的编写之前,我先说一下.net framework下我们MVC控件的做法. MVC下控件的写法,主要有如下三种,最后一种是泛型的写法,mvc提供的控件都是基本控件. ...
- HTML5的新语义化的标签
在HTML5之前采用HTML+CSS文档结构写法 [ID选择器说明 id选择器——用于标识页面上特定元素(比如站点导航.页眉.页脚)而且必须唯一; 也可以用来标识持久结构性元素(如主导航.内容区域)] ...
- js拖拽
- Android事件分发机制浅谈(二)--源码分析(ViewGroup篇)
上节我们大致了解了事件分发机制的内容,大概流程,这一节来分析下事件分发的源代码. 我们先来分析ViewGroup中dispatchTouchEvent()中的源码 public boolean dis ...
- 基于JQuery实现的文本框自动填充功能
1. 实现的方法 /* * js实现的文本框的自动完成功能 */ function doAutoComplete(textid,dataid,url){ $("#" + texti ...
- Java 性能分析工具 , 第 1 部分: 操作系统工具
引言 性能分析的前提是将应用程序内部的运行状况以及应用运行环境的状况以一种可视化的方式更加直接的展现出来,如何来达到这种可视化的展示呢?我们需要配合使用操作系统中集成的程序监控工具和 Java 中内置 ...
- MVC 后台管理框架 FineUIMvc 在线示例
FineUIMvc 在线示例 基础版下载