Python 自动化运维 smtplib

简介:

  1.实现邮件的发送功能

  

  2.基础使用

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import  smtplib      ##导入模块
import  string
HOST  =  "smtp.163.com"     ##定义远程smtp主机
SUBJECT  =  " TEST"         ##定义发送主题
TO  =  "1287112485@qq.com"         ##定义接收主机
FROM  =  "18502942450@163.com"    ##定义发送主机
text  =  "python"         ##    ##定义邮件内容
BODY  =  string.join((          ##定义发送格式内容
     "From: %s"  % FROM,
     "To : %s"  % TO,
     "Subject: %s "  % SUBJECT,
     "",
     text
     ), "\r\n" )
server  =  smtplib.SMTP()     ##实例化
server.connect(HOST, "25" )      ##连接远程主机
server.starttls()           ##启用TLS(安全传输)模式
server.login( "18502942450@163.com" , "ws128711" )    ##校验远程主机
server.sendmail(FROM,[TO],BODY)       ##邮件发送功能[发送人,接收人,内容]
server.quit()

## 出现550错误时,打开邮箱客户端授权码

wKiom1neOAWiCToxAAPAa2q7ctc700.png



测试

wKiom1neODLAc0gZAASBf5ahbek528.png


   3.个性化邮件

MIME类:它是一个互联网标准,扩展了电子邮件标准,使其能够支持,非ASCII字符文本;非文本格式附件(二进制、声音、图像等),由多部分(multiple parts)组成的消息体,包含非ASCII字符的头信息。

实例:发送html文件

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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
import  smtplib
from  email.mime.text  import  MIMEText     ##导入MIMEText类
import  string
HOST  =  "smtp.163.com"
SUBJECT  =  " TEST"
TO  =  "1287112485@qq.com"
FROM  =  "18502942450@163.com"
msg  =  MIMEText( """               ##创建MIME对象,制定HTML内容,类型,字符编码等
<html>
        
<head>       
     <meta http-equiv="Content-Type"       
           content="text/html; charset=ISO-8859-1" />       
     <title></title>       
     <style type="text/css">       
         table.diff {font-family:Courier; border:medium;}       
         .diff_header {background-color:#e0e0e0}       
         td.diff_header {text-align:right}       
         .diff_next {background-color:#c0c0c0}       
         .diff_add {background-color:#aaffaa}       
         .diff_chg {background-color:#ffff77}       
         .diff_sub {background-color:#ffaaaa}       
     </style>       
</head>       
        
<body>       
            
     <table class="diff" id="difflib_chg_to0__top"       
            cellspacing="0" cellpadding="0" rules="groups" >       
         <colgroup></colgroup> <colgroup></colgroup> <colgroup></colgroup>       
         <colgroup></colgroup> <colgroup></colgroup> <colgroup></colgroup>       
                
         <tbody>       
             <tr><td class="diff_next" id="difflib_chg_to0__0"><a href="#difflib_chg_to0__0">f</a></td><td class="diff_header" id="from0_1">1</td><td nowrap="nowrap"></td><td class="diff_next"><a href="#difflib_chg_to0__0">f</a></td><td class="diff_header" id="to0_1">1</td><td nowrap="nowrap"></td></tr>       
             <tr><td class="diff_next"><a href="#difflib_chg_to0__top">t</a></td><td class="diff_header" id="from0_2">2</td><td nowrap="nowrap">wwwwdwed</td><td class="diff_next"><a href="#difflib_chg_to0__top">t</a></td><td class="diff_header" id="to0_2">2</td><td nowrap="nowrap">wwwwdwed<span class="diff_add">efwe</span></td></tr>       
             <tr><td class="diff_next"></td><td class="diff_header" id="from0_3">3</td><td nowrap="nowrap"><span class="diff_sub">wwwdwqed&nbsp;</span></td><td class="diff_next"></td><td class="diff_header" id="to0_3">3</td><td nowrap="nowrap"><span class="diff_add">wwdwqedewf</span></td></tr>       
             <tr><td class="diff_next"></td><td class="diff_header" id="from0_4">4</td><td nowrap="nowrap">wwefwe</td><td class="diff_next"></td><td class="diff_header" id="to0_4">4</td><td nowrap="nowrap">wwefwe</td></tr>       
             <tr><td class="diff_next"></td><td class="diff_header" id="from0_5">5</td><td nowrap="nowrap">wwgwte</td><td class="diff_next"></td><td class="diff_header" id="to0_5">5</td><td nowrap="nowrap">wwgwte</td></tr>       
             <tr><td class="diff_next"></td><td class="diff_header" id="from0_6">6</td><td nowrap="nowrap">wtgq</td><td class="diff_next"></td><td class="diff_header" id="to0_6">6</td><td nowrap="nowrap">wtgq</td></tr>       
         </tbody>       
     </table>       
     <table class="diff" summary="Legends">       
         <tr> <th colspan="2"> Legends </th> </tr>       
         <tr> <td> <table border="" summary="Colors">       
                       <tr><th> Colors </th> </tr>       
                       <tr><td class="diff_add">&nbsp;Added&nbsp;</td></tr>       
                       <tr><td class="diff_chg">Changed</td> </tr>       
                       <tr><td class="diff_sub">Deleted</td> </tr>       
                   </table></td>       
              <td> <table border="" summary="Links">       
                       <tr><th colspan="2"> Links </th> </tr>       
                       <tr><td>(f)irst change</td> </tr>       
                       <tr><td>(n)ext change</td> </tr>       
                       <tr><td>(t)op</td> </tr>       
                   </table></td> </tr>       
     </table>       
</body>       
        
</html>       
""" ,"html", 'utf-8' )
msg[ "Subject" =  SUBJECT   ##邮件主题
msg[ "From" =  FROM        
msg[ "to"  =  TO
try :
     server  =  smtplib.SMTP()
     server.connect(HOST, "25" )
     server.starttls()
     server.login( "18502942450@163.com" , "ws128711" )
     server.sendmail(FROM,[TO],msg.as_string())
     server.quit()       ##断开连接
     print  "ok"  
except  Exception,e:
     print  "error:"  +  str (e)

测试


wKiom1neOiiSNI2kAASqgHv7xeQ770.png

本文转自  red777    51CTO博客,原文链接:http://blog.51cto.com/12314711/1971457

相关文章
|
26天前
|
搜索推荐 Python
使用Python自动化生成物业通知单
本文介绍如何使用Python结合Pandas和python-docx库自动化生成物业通知单。通过读取Excel数据并填充至Word模板,实现高效准确的通知单批量制作。包括环境准备、代码解析及效果展示,适用于物业管理场景。
60 14
|
30天前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####
|
4天前
|
Python
自动化微信朋友圈:Python脚本实现自动发布动态
本文介绍如何使用Python脚本自动化发布微信朋友圈动态,节省手动输入的时间。主要依赖`pyautogui`、`time`、`pyperclip`等库,通过模拟鼠标和键盘操作实现自动发布。代码涵盖打开微信、定位朋友圈、准备输入框、模拟打字等功能。虽然该方法能提高效率,但需注意可能违反微信使用条款,存在风险。定期更新脚本以适应微信界面变化也很重要。
104 60
|
2月前
|
数据采集 监控 数据挖掘
Python自动化脚本:高效办公新助手###
本文将带你走进Python自动化脚本的奇妙世界,探索其在提升办公效率中的强大潜力。随着信息技术的飞速发展,重复性工作逐渐被自动化工具取代。Python作为一门简洁而强大的编程语言,凭借其丰富的库支持和易学易用的特点,成为编写自动化脚本的首选。无论是数据处理、文件管理还是网页爬虫,Python都能游刃有余地完成任务,极大地减轻了人工操作的负担。接下来,让我们一起领略Python自动化脚本的魅力,开启高效办公的新篇章。 ###
|
16天前
|
JSON 数据可视化 测试技术
python+requests接口自动化框架的实现
通过以上步骤,我们构建了一个基本的Python+Requests接口自动化测试框架。这个框架具有良好的扩展性,可以根据实际需求进行功能扩展和优化。它不仅能提高测试效率,还能保证接口的稳定性和可靠性,为软件质量提供有力保障。
48 7
|
1月前
|
Android开发 开发者 Python
通过标签清理微信好友:Python自动化脚本解析
微信已成为日常生活中的重要社交工具,但随着使用时间增长,好友列表可能变得臃肿。本文介绍了一个基于 Python 的自动化脚本,利用 `uiautomator2` 库,通过模拟用户操作实现根据标签批量清理微信好友的功能。脚本包括环境准备、类定义、方法实现等部分,详细解析了如何通过标签筛选并删除好友,适合需要批量管理微信好友的用户。
51 7
|
30天前
|
安全 API 文件存储
Yagmail邮件发送库:如何用Python实现自动化邮件营销?
本文详细介绍了如何使用Yagmail库实现自动化邮件营销。Yagmail是一个简洁强大的Python库,能简化邮件发送流程,支持文本、HTML邮件及附件发送,适用于数字营销场景。文章涵盖了Yagmail的基本使用、高级功能、案例分析及最佳实践,帮助读者轻松上手。
35 4
|
29天前
|
敏捷开发 测试技术 持续交付
自动化测试之美:从零开始搭建你的Python测试框架
在软件开发的马拉松赛道上,自动化测试是那个能让你保持节奏、避免跌宕起伏的神奇小助手。本文将带你走进自动化测试的世界,用Python这把钥匙,解锁高效、可靠的测试框架之门。你将学会如何步步为营,构建属于自己的测试庇护所,让代码质量成为晨跑时清新的空气,而不是雾霾中的忧虑。让我们一起摆脱手动测试的繁琐枷锁,拥抱自动化带来的自由吧!
|
2月前
|
机器学习/深度学习 运维 监控
智能化运维:从自动化到AIOps的演进之路####
本文深入探讨了IT运维领域如何由传统手工操作逐步迈向高度自动化,并进一步向智能化运维(AIOps)转型的过程。不同于常规摘要仅概述内容要点,本摘要将直接引入一个核心观点:随着云计算、大数据及人工智能技术的飞速发展,智能化运维已成为提升企业IT系统稳定性与效率的关键驱动力。文章详细阐述了自动化工具的应用现状、面临的挑战以及AIOps如何通过预测性分析和智能决策支持,实现运维工作的质变,引领读者思考未来运维模式的发展趋势。 ####
|
2月前
|
机器学习/深度学习 数据采集 人工智能
智能化运维:从自动化到AIOps的演进与实践####
本文探讨了智能运维(AIOps)的崛起背景,深入分析了其核心概念、关键技术、应用场景及面临的挑战,并对比了传统IT运维模式,揭示了AIOps如何引领运维管理向更高效、智能的方向迈进。通过实际案例分析,展示了AIOps在不同行业中的应用成效,为读者提供了对未来智能运维趋势的洞察与思考。 ####
91 1