#!/usr/bin/env python

# -*- coding:utf-8 -*-

import smtplib

from email.mime.multipart import MIMEMultipart

from email.mime.text import MIMEText

from email.mime.application import MIMEApplication

from email.header import Header

import datetime

import os.path

import createsheet

import base64

import sys

reload(sys)

sys.setdefaultencoding('utf8')

oct21st=datetime.datetime.now()

nowday=oct21st.strftime('%Y-%m-%d')

class Mailer(object):

def __init__(self,maillist,mailtitle,mailcontent):

self.mail_list = maillist

self.mail_title = mailtitle

self.mail_content = mailcontent

#    self.mail_host = "smtp.163.com"

#    self.mail_user = "*"

#    self.mail_pass = "*"

#    self.mail_postfix = "*"

self.mail_host = "smtp.exmail.qq.com"

self.mail_user = "*"

self.mail_pass = "*"

self.mail_postfix = "*"

def sendMail(self):

#创建一个带附件的实例

#加邮件头,设置根容器属性

## 构造MIMEMultipart对象做为根容器

me = self.mail_user + "<" + self.mail_user+">"

msg = MIMEMultipart()

msg['Subject'] = Header(self.mail_title, 'utf-8')

msg['From'] = me

msg['To'] = ";".join(self.mail_list)

#添加邮件内容

#注意,要指定邮件内容的编码为utf-8,否则中文会有乱码

#构造MIMEText对象做为邮件显示内容并附加到根容器

#puretext = MIMEText('<h1>你好,<br/>'+self.mail_content+'</h1>','html','utf-8')

puretext = MIMEText('Hi:\n见附件','plain','utf-8')

msg.attach(puretext)

# jpg类型的附件

#    jpgpart = MIMEApplication(open('/home/mypan/1949777163775279642.jpg', 'rb').read())

#    jpgpart.add_header('Content-Disposition', 'attachment', filename='beauty.jpg')

#    msg.attach(jpgpart)

# 首先是xlsx类型的附件

# 设置附件头

xlsxname='C:\Users\Administrator\Desktop\内容\* '+nowday+'.xlsx'

#    filename=os.path.basename(xlsxname).encode('gb2312')

filename=os.path.basename(xlsxname)

xlsxpart = MIMEApplication(open(xlsxname.decode('utf-8'), 'rb').read())

xlsxpart.add_header('Content-Disposition', 'attachment', filename='=?utf-8?b?'+base64.b64encode(filename.encode('utf-8'))+'?=')

msg.attach(xlsxpart)

# mp3类型的附件

#mp3part = MIMEApplication(open('kenny.mp3', 'rb').read())

#mp3part.add_header('Content-Disposition', 'attachment', filename='benny.mp3')

#msg.attach(mp3part)

# pdf类型附件

#part = MIMEApplication(open('foo.pdf', 'rb').read())

#part.add_header('Content-Disposition', 'attachment', filename="foo.pdf")

#msg.attach(part)

try:

s = smtplib.SMTP() #创建邮件服务器对象

s.connect(self.mail_host) #连接到指定的smtp服务器。参数分别表示smpt主机和端口

s.login(self.mail_user, self.mail_pass) #登录到你邮箱

s.sendmail(me, self.mail_list, msg.as_string()) #发送内容

s.close()

return True

except Exception, e:

print str(e)

return False

def send_mail():

createsheet.createsheet()

mailto_list = ["*"]

mail_title = '你好'

mail_content = 'Hey this is content'

mm = Mailer(mailto_list,mail_title,mail_content)

res = mm.sendMail()

print res

if __name__ == '__main__':

#send list

send_mail()

python自动化之邮件发送的更多相关文章

  1. python 自动化实现定时发送html报告到邮箱

    # coding =utf-8 import os import unittest import time import datetime import smtplib from email.mime ...

  2. 多测师讲解自动化 _邮件发送_高级讲师肖sir

    第一步.进入如下网址申请163邮箱. https://mail.163.com/ 第二步.注册完之后登录.点击如下图设置­点击POP3/SMTP/IMAP. 第三步.右侧点击客户端授权密码. 第四步. ...

  3. Selenium+Python之163邮件发送

    今晚写了一个163邮箱登录的脚本,由于不停的访问163登录主页导致直接访问163邮箱主页登录需要输入验证码,因为无法获取到验证码,就这导致直接访问主页登录脚本不可行,为了绕过验证码,现在先访问hao1 ...

  4. 【python】smtp邮件发送

    纯文本: #!/usr/bin/env python3 #coding: utf-8 import smtplib from email.mime.text import MIMEText from ...

  5. 用python SMTP进行邮件发送

    import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart & ...

  6. python SMTP邮件发送(转载)

    Python SMTP发送邮件 SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式. py ...

  7. python selenium2示例 - email发送

    前言 在进行日常的自动化测试实践中,我们总是需要将测试过程中的记录.结果等等等相关信息通过自动的手段发送给相关人员.python的smtplib.email模块为我们提供了很好的email发送等功能的 ...

  8. 测试开发【提测平台】分享11-Python实现邮件发送的两种方法实践

    微信搜索[大奇测试开],关注这个坚持分享测试开发干货的家伙. 按照开发安排,本篇本应该是关于提测页面的搜索和显示实现,怕相似内容疲劳,这期改下内容顺序,将邮件服务的相关的提前,在之前的产品需求和原型中 ...

  9. 【Python + Selenium3】自动化测试之DDT数据驱动并生成测试报告以及用yagmail邮件发送文件

    我的文件路径 一.DDT代码: import unittest from time import sleep from selenium import webdriver from ddt impor ...

随机推荐

  1. MYSQL创建表的约束条件(可选)

    一.常用的一些约束条件 一.创建表的完整语法1.创建表的万能模板:create table 库名.表名( 字段名1 类型[(宽度) 约束条件], 字段名2 类型[(宽度) 约束条件], 字段名3 类型 ...

  2. CobarClient源码分析

    CobarClient是阿里巴巴公司开发一个的开源的.基于iBatis和Spring的分布式数据库访问层.为了支持iBatis,Spring框架提供了一个SqlMapClientTemplate,通过 ...

  3. ASP.NET Application Life Cycle

    The table in this topic details the steps performed while an XAF ASP.NET application is running. Not ...

  4. day01_概念

    1 网络分类: 1 按照范围: - 局域网:范围很小的网络,如一间办公室,一个公司 - 城域网:大致城市范围内的网络,半径几公里到几十公里 - 广域网:比城域网范围更大的 2 网络衡量标准 1 传输速 ...

  5. 布线问题 (NYOJ38)

    布线问题 时间限制:1000 ms  |  内存限制:65535 KB 难度:4   描述 南阳理工学院要进行用电线路改造,现在校长要求设计师设计出一种布线方式,该布线方式需要满足以下条件:1.把所有 ...

  6. c++三大概念要分清--重载,隐藏(重定义),覆盖(重写)

    重载,隐藏(重定义),覆盖(重写)—这几个名词看着好像很像,不过其实一样都不一样!! 综述: 说明:覆盖中的访问修饰符可以不同是指可以不用显示地用virtual:当访问修饰符改为const或者stat ...

  7. PHP核心技术——异常和错误处理

    PHP只有手动抛出异常后才能捕获异常 $a = null; try { $a = 5/0; echo $a,PHP_EOL; } catch (exception $e) { $e -> get ...

  8. 关于nodejs中遇到mysql默认8小时连接断开机制的终极简单解决方案

    由于mysql默认8小时连接无访问,就会断开.为此查了一下资料,有同种比较简单的解决方案: 1. 增加 MySQL 的 wait_timeout 属性的值. 修改 /etc/mysql/my.cnf文 ...

  9. Django数据库 相关之select_related/prefetch_related

    - 性能相关 user_list = models.UserInfo.objects.all() for row in user_list: # 只去取当前表数据 select_related,主动连 ...

  10. JSBridge的原理

    前言 参考来源 前人栽树,后台乘凉,本文参考了以下来源 github-WebViewJavascriptBridge JSBridge-Web与Native交互之iOS篇 Ios Android Hy ...