网络编程
位置:首页>> 网络编程>> Python编程>> python脚本定时发送邮件

python脚本定时发送邮件

作者:缘自天方  发布时间:2023-08-07 16:36:02 

标签:python,发送邮件

本文实例为大家分享了python定时发送邮件的具体代码,供大家参考,具体内容如下

全部代码如下:


import time
from datetime import datetime
from email.header import Header
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.utils import parseaddr, formataddr

import xlrd
from apscheduler.schedulers.blocking import BlockingScheduler
from xlrd import xldate_as_tuple

ISOTIMEFORMAT = '%Y%m%d'
import smtplib

def read_file(file_path):
 file_list = []
 work_book = xlrd.open_workbook(file_path)
 sheet_data = work_book.sheet_by_name('Sheet1')
 print('now is process :', sheet_data.name)
 Nrows = sheet_data.nrows

for i in range(1, Nrows):
   file_list.append(sheet_data.row_values(i))

return file_list

def _format_addr(s):
 name, addr = parseaddr(s)
 return formataddr((Header(name, 'utf-8').encode(), addr))

def sendEmail(from_addr, password, to_addr, smtp_server, file_list):
 nowDate = str(time.strftime(ISOTIMEFORMAT, time.localtime()))
 html_content_start = \
   '''
   <html>
   <body>
     <p>hi,All:</p>
     <table border="0"width="95%"height="50%"cellpadding="1"style="margin:15px"cellspacing="1"bordercolor="#D3D3D3"bgcolor="#9F9F9F">
       <tr bgcolor="#D3D3D3" style="margin:10px">
         <th style="padding:6;font-size:16">工作事项</th>
         <th style="padding:6;font-size:16">负责人</th>
         <th style="padding:6;font-size:16">进度</th>
         <th style="padding:6;font-size:16">风险与问题</th>
       </tr>
   '''
 for i in range(len(file_list)):
   work = file_list[i]
   workdata, person_name, progress, issue = str(work[0]), str(work[1]), str(work[2]), str(work[3])
   if '.' in str(work[2]): # 填的数字
     progress = "%.0f%%" % (work[2] * 100) # 浮点转成百分比

updateTime = xldate_as_tuple(work[4], 0)
   value = datetime(*updateTime)
   # 先转换为时间数组,然后转换为其他格式
   timeStruct = time.strptime(str(value), "%Y-%m-%d %H:%M:%S")
   uptTime = str(time.strftime("%Y%m%d", timeStruct))
   if uptTime != nowDate:
     raise RuntimeError('有人没有更新最新记录:' + str(work[1]))

html_content_suffer = \
     '''
         <tr bgcolor="#FFFFFF" >
           <td style="padding:6;font-size:14">{workdata}</td>
           <td style="padding:6;font-size:14">{person_name}</td>
           <td style="padding:6;font-size:14">{progress}</td>
           <td style="padding:6;font-size:14">{issue}</td>
         </tr>
     '''.format(workdata=workdata.replace('\n', '<br>'), person_name=person_name, progress=progress, issue=issue)
   html_content_start += html_content_suffer

html_content_end = \
   '''
     </table>
   </body>
   </html>
   '''
 html_content = html_content_start + html_content_end

try:
   msg = MIMEMultipart()
   msg.attach(MIMEText(html_content, 'html', 'utf-8'))
   msg['From'] = _format_addr('发送方 <%s>' % from_addr)
   msg['To'] = _format_addr(to_addr + '<%s>' % to_addr)
   msg['Subject'] = Header('主题' + nowDate, 'utf-8').encode()

server = smtplib.SMTP_SSL(smtp_server, 465)
   server.login(from_addr, password) # 登录邮箱服务器
   server.sendmail(from_addr, [to_addr], msg.as_string()) # 发送信息
   server.quit()
   print("from_addr:" + str(from_addr), " to_addr:", to_addr, "已发送成功!")
 except Exception as e:
   print("发送失败" + e)

def job():
 root_dir = 'D:\\develop\\python\\file'
 file_path = root_dir + "\\excel.xlsx"
 from_addr = 'aaa@163.com' # 邮箱登录用户名
 password = 'mima' # 登录密码
 smtp_server = 'smtp.com' # 服务器地址,默认端口号25
 to_addr = 'aaa@163.com' # 接收方邮箱

file_list = read_file(file_path)
 sendEmail(from_addr, password, to_addr, smtp_server, file_list)
 print('发送完成')

if __name__ == '__main__':
 # 该示例代码生成了一个BlockingScheduler调度器,使用了默认的任务存储MemoryJobStore,以及默认的执行器ThreadPoolExecutor,并且最大线程数为10。

# BlockingScheduler:在进程中运行单个任务,调度器是唯一运行的东西
 scheduler = BlockingScheduler()
 # 采用阻塞的方式

# 采用corn的方式,每天18点发送
 scheduler.add_job(job, 'cron', hour='18')
 '''
   year (int|str) – 4-digit year
   month (int|str) – month (1-12)
   day (int|str) – day of the (1-31)
   week (int|str) – ISO week (1-53)
   day_of_week (int|str) – number or name of weekday (0-6 or mon,tue,wed,thu,fri,sat,sun)
   hour (int|str) – hour (0-23)
   minute (int|str) – minute (0-59)
   econd (int|str) – second (0-59)
   start_date (datetime|str) – earliest possible date/time to trigger on (inclusive)
   end_date (datetime|str) – latest possible date/time to trigger on (inclusive)
   timezone (datetime.tzinfo|str) – time zone to use for the date/time calculations (defaults to scheduler timezone)
   *  any  Fire on every value
   */a  any  Fire every a values, starting from the minimum
   a-b  any  Fire on any value within the a-b range (a must be smaller than b)
   a-b/c  any  Fire every c values within the a-b range
   xth y  day  Fire on the x -th occurrence of weekday y within the month
   last x  day  Fire on the last occurrence of weekday x within the month
   last  day  Fire on the last day within the month
   x,y,z  any  Fire on any matching expression; can combine any number of any of the above expressions
   '''
 scheduler.start()

表格如下:

python脚本定时发送邮件

如果放在linux系统中执行,上述脚本不能执行成功,是因为对编码等有要求,全部更新代码如下:


#coding=utf-8
import time
from datetime import datetime
from email.header import Header
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.utils import parseaddr, formataddr

import sys

import xlrd
from apscheduler.schedulers.blocking import BlockingScheduler
from xlrd import xldate_as_tuple

ISOTIMEFORMAT = '%Y%m%d'
import smtplib
import logging
logging.basicConfig()

def read_file(file_path):
 file_list = []
 work_book = xlrd.open_workbook(file_path)
 sheet_data = work_book.sheet_by_name('Sheet1')
 print('now is process :', sheet_data.name)
 Nrows = sheet_data.nrows

for i in range(1, Nrows):
   file_list.append(sheet_data.row_values(i))

return file_list

def _format_addr(s):
 name, addr = parseaddr(s)
 return formataddr((Header(name, 'utf-8').encode(), addr))

def sendEmail(from_addr, password, to_addr, smtp_server, file_list):
 nowDate = str(time.strftime(ISOTIMEFORMAT, time.localtime()))
 html_content_start = \
   '''
   <html>
   <body>
     <p>hi,All:</p>
     <table border="0"width="95%"height="50%"cellpadding="1"style="margin:15px"cellspacing="1"bordercolor="#D3D3D3"bgcolor="#9F9F9F">
       <tr bgcolor="#D3D3D3" style="margin:10px">
         <th style="padding:6;font-size:16">工作事项</th>
         <th style="padding:6;font-size:16">负责人</th>
         <th style="padding:6;font-size:16">进度</th>
         <th style="padding:6;font-size:16">风险与问题</th>
       </tr>
   '''
 for i in range(len(file_list)):
   work = file_list[i]
   workdata, person_name, progress, issue = str(work[0]), str(work[1]), str(work[2]), str(work[3])
   if '.' in str(work[2]): # 填的数字
     progress = "%.0f%%" % (work[2] * 100) # 浮点转成百分比

updateTime = xldate_as_tuple(work[4], 0)
   value = datetime(*updateTime)
   # 先转换为时间数组,然后转换为其他格式
   timeStruct = time.strptime(str(value), "%Y-%m-%d %H:%M:%S")
   uptTime = str(time.strftime("%Y%m%d", timeStruct))
   if uptTime != nowDate:
     raise RuntimeError('有人没有更新最新记录:' + str(work[1]))

html_content_suffer = \
     '''
         <tr bgcolor="#FFFFFF" >
           <td style="padding:6;font-size:14">{workdata}</td>
           <td style="padding:6;font-size:14">{person_name}</td>
           <td style="padding:6;font-size:14">{progress}</td>
           <td style="padding:6;font-size:14">{issue}</td>
         </tr>
     '''.format(workdata=workdata.replace('\n', '<br>'), person_name=person_name.replace('\n', '<br>'), progress=progress.replace('\n', '<br>'), issue=issue.replace('\n', '<br>'))
   html_content_start += html_content_suffer

html_content_end = \
   '''
     </table>
   </body>
   </html>
   '''
 html_content = html_content_start + html_content_end

try:
   msg = MIMEMultipart()
   msg.attach(MIMEText(html_content, 'html', 'utf-8'))
   msg['From'] = _format_addr('发送方 <%s>' % from_addr)
   msg['To'] = _format_addr(to_addr + '<%s>' % to_addr)
   msg['Subject'] = Header('主题' + nowDate, 'utf-8').encode()

server = smtplib.SMTP_SSL(smtp_server, 465)
   server.login(from_addr, password) # 登录邮箱服务器
   server.sendmail(from_addr, [to_addr], msg.as_string()) # 发送信息
   server.quit()
   print("from_addr:" + str(from_addr), " to_addr:", to_addr, "已发送成功!")
 except Exception as e:
   print("发送失败" + e)

def job():
 root_dir = 'D:\\develop\\python\\file'
 file_path = root_dir + "\\excel.xlsx"
 from_addr = 'aaa@163.com' # 邮箱登录用户名
 password = 'mima' # 登录密码
 smtp_server = 'smtp.com' # 服务器地址,默认端口号25
 to_addr = 'aaa@163.com' # 接收方邮箱

file_list = read_file(file_path)
 sendEmail(from_addr, password, to_addr, smtp_server, file_list)
 print('发送完成')

if __name__ == '__main__':
 # 该示例代码生成了一个BlockingScheduler调度器,使用了默认的任务存储MemoryJobStore,以及默认的执行器ThreadPoolExecutor,并且最大线程数为10。

# BlockingScheduler:在进程中运行单个任务,调度器是唯一运行的东西
 scheduler = BlockingScheduler()
 # 采用阻塞的方式

reload(sys)

sys.setdefaultencoding("utf8")

# 采用corn的方式
 scheduler.add_job(job, 'cron', hour='21', minute='0')
 '''
   year (int|str) – 4-digit year
   month (int|str) – month (1-12)
   day (int|str) – day of the (1-31)
   week (int|str) – ISO week (1-53)
   day_of_week (int|str) – number or name of weekday (0-6 or mon,tue,wed,thu,fri,sat,sun)
   hour (int|str) – hour (0-23)
   minute (int|str) – minute (0-59)
   econd (int|str) – second (0-59)
   start_date (datetime|str) – earliest possible date/time to trigger on (inclusive)
   end_date (datetime|str) – latest possible date/time to trigger on (inclusive)
   timezone (datetime.tzinfo|str) – time zone to use for the date/time calculations (defaults to scheduler timezone)
   *  any  Fire on every value
   */a  any  Fire every a values, starting from the minimum
   a-b  any  Fire on any value within the a-b range (a must be smaller than b)
   a-b/c  any  Fire every c values within the a-b range
   xth y  day  Fire on the x -th occurrence of weekday y within the month
   last x  day  Fire on the last occurrence of weekday x within the month
   last  day  Fire on the last day within the month
   x,y,z  any  Fire on any matching expression; can combine any number of any of the above expressions
   '''
 scheduler.start()

来源:https://blog.csdn.net/qq_35956041/article/details/102574867

0
投稿

猜你喜欢

  • 本程序有两文件test.asp 和tree.asp 还有一些图标文件   1。test.asp 调用类生成树 代码如下<%@
  • <%           &nbs
  • 流动网页设计有很多好处,但也只有在正确使用的时候。合适的技巧会使页面在大屏幕、小屏幕抑、PDA小屏幕上都能得到良好的呈现。但是,糟糕的代码结
  • 处理办法,删除该文件,或清空该文件内容;我的处理是清空后,再设置该文件权限为Everyone拒绝访问。
  •     以前的Dreamweaver中是没有图片处理功能的,即使你要处理也只能使用CSS中的相关滤镜进行一些效
  • MySQL是中小型网站普遍使用的数据库之一,然而,很多人并不清楚MySQL到底能支持多大的数据量,再加上某些国内CMS厂商把数据承载量的责任
  • 当一张的数据达到几百万时,你查询一次所花的时间会变多,如果有联合查询的话,我想有可能会死在那儿了。分表的目的就在于此,减小数据库的负担,缩短
  • 先把我的browser信息说明一下:这是在opera里about中显示的“浏览器识别”Opera/9.62 (Windows NT 5.1;
  • 变量名1、组成:数字、字母、下划线2、变量名要有意义3、多个单词则用下划线,如user_id4、python的变量名不要驼峰显示字符串:1、
  • 在大型的ASP项目中,很多的页面都涉及到分页、翻页功能。如果每个页面都写一个翻页的程序的话,这样的工作即降低了工作效率,也不利于工程的模块化
  • 前边看到有人发了个层打开效果,总感觉不是很理想 个人认为:-),如果那个层放到固定的容器里面估计就会出现问题的。今天自己来写个,可以支持 在
  • 看新闻说Chrome的Javascript引擎很强大,执行速度很快。就随便写了一个1,000,000次的累加放到IE和Chrome下测试,效
  • 当你在IE中点击一个Realplayer连接时,系统会自动启动Realplayer软件,不仅占用系统内存,而且在上网时Realplayer容
  • 要将身份证的正反面图片合并为一张图片,你可以使用PHP的GD库来完成。演示了如何合并两张图片下面是一个示例代码,演示了如何合并两张图片://
  • 如何只取数据库的前3条记录?怎么控制只取得前3行数据    这要看是什么类型的数据库了,对于Access和SQ
  • 经常看到说正则的文章,但说的只是方法,却很少有说以下几个基本概念:1.贪婪:+,*,?,{m,n}等默认是贪婪匹配,即尽可能多匹配,也叫最大
  • 在上一期中作者向诸位简要介绍了 ASP 脚本语言之一 VBScript 的一些基本常识,本期将继续给大家讲解 VBScript 的脚本编写方
  • 注:本文的所有数据请移步&mdash;&mdash; 参考数据一、水平堆叠图堆叠图其实就是柱状图的一种特殊形式fr
  • 概述编程的内核是数学,而测试的本质是计算,专业名词叫容量预估,而测试的大体就是用程序模拟程序,检测程序的正确性,有两个点需要注意,QPS最佳
  • 本文实例为大家分享了python绘制汉诺塔的具体代码,供大家参考,具体内容如下源码:import turtleclass Stack: &n
手机版 网络编程 asp之家 www.aspxhome.com