python发送邮件脚本
作者:RangeYan 发布时间:2022-01-28 03:04:58
标签:python,发送邮件
本文实例为大家分享了python发送邮件的具体代码,供大家参考,具体内容如下
#!/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()
来源:https://blog.csdn.net/yanshu2012/article/details/50396068


猜你喜欢
- 前言在 Go 语言中,有一种特殊的用法可能让许多人感到困惑,那就是空结构体 struct{}。在本文中,我将对
- 正在看的ORACLE教程是:常见数据库系统比较 Oracle数据库。提起数据库,第一个想到的公司,一般都会是Oracle。该公司
- 本文为大家分享了Python创建单例模式的5种常用方法,供大家参考,具体内容如下所谓单例,是指一个类的实例从始至终只能被创建一次。方法1:如
- 为什么需要协程协程的本质是将一段数据的运行状态进行打包,可以在线程之间调度,所以协程就是在单线程的环境下实现的应用程序级别的并发,就是把本来
- PHP mysqli_sqlstate() 函数返回最后一个 MySQL 操作的 SQLSTATE 错误代码:<?php// 假定数据
- 看完本篇文章你可以:同步本地和服务器的全部或者部分文件本地debug,服务器跑实验在这之前你要确保服务器上已经创建好虚拟环境你本地已经安装好
- 关于一些代码里的解释,可以看我上一篇发布的文章,里面有很详细的介绍!!!可以依次把下面的代码段合在一起运行,也可以通过jupyter not
- 函数使用单下划线_开头使用单下划线(_)开头的函数_func不能被模块外部以: from module import *形式导入。但可以用:
- set ANSI_NULLS ON set QUOTED_IDENTIFIER ON go Create PROCEDURE [dbo].[
- OpenCV中circle与rectangle函数显示,只不过rectangle在图像中画矩形,circle在图像中画圆。void circ
- 目前,各大搜索引擎如google、百度、雅虎已经对动态页面诸如asp,php有着不错的支持了,只要动态页面后面的参数不要太长,如控制在3个参
- 看代码吧~import numpy as npa = np.array([[2, 4, 6, 1], [1, 5, 2, 9]])print
- 慢SQL与索引的关系慢SQL优化原则数据库也是应用,MySQL 作为一种磁盘数据库,属于典型的 IO 密集型应用,并且随机 IO 比顺序 I
- 1.对于RGB三通道图片,直接用两层for循环的话,效率比较低2.可以先将RGB图片转为灰度图片,再利用numpy.where的广播机制统计
- 本文实例讲述了原生JS实现Ajax通过POST方式与PHP进行交互的方法。分享给大家供大家参考,具体如下:一、代码conn.php<?
- 从MySQL支持Unicode后,为了与时俱进,我们的web程序也开始考虑用UTF8了。其实UTF8也用了好几年了,程序基本能跑,没什么大问
- 本文实例讲述了php基于PDO实现功能强大的MYSQL封装类。分享给大家供大家参考,具体如下:class CPdo{ protected $
- 网络爬虫,是在网上进行数据抓取的程序,使用它能够抓取特定网页的HTML数据。虽然我们利用一些库开发一个爬虫程序,但是使用框架可以大大提高效率
- 一、CSS HACK以下两种方法几乎能解决现今所有HACK.1, !important随着IE7对!important的支持, !impor
- 前言今天我看了一下自己的文件夹,发现了自己写了许多似乎很无聊的代码。于是乎,一个想法油然而生:“生活已经很无聊了,不如再无聊一点叭”。说干就