前言

在工作中,有时会有一些定期需要执行的任务或在将来某一天需要执行的任务,为避免疏漏,设计个小工具,发邮件提醒自己去处理.

方案简介

1.建立一个Excel文件,里面定义好待提醒的任务

2.建立一个记事本文件,里面输入待接收邮件的邮箱账号

3.采用Python编写代码,读取Excel文件,检查是否该发送提醒邮件,如果需要提醒,则发出邮件给接收人。

4.把python编写的代码,打包成exe可执行文件

5.采用Windows的定时任务作业,调度打包好的exe文件

适用环境:

1.Windows平台

2.已经配置好可以收发邮件的Outlook

详细方案:

1.Excel名称:Task.xlsx,sheet名:sheet1

说明:

1)、Frequency列,执行频率

2)、Item列,分如下三种情况

a.当Frequency为Week,Item为Monday,表明周一需要执行,Item可填写的内容为英文星期

b.当Frequency为Month,Item为1-30中间的某个数值,在当月那一天执行

c.当Frequency为Day,Item为具体日期,表明到了指定日期,发出提醒邮件,注意填写的日期格式:yyyy-mm-dd

Item这一列,设置为文本格式

3)、Task为发送邮件的提醒内容

4)、是否处理,如果为Y ,则表明已经处理过了,无需再发提醒邮件

2.记事本,config.txt,里面填写待接收邮件的邮箱账号,如果是多个人,则邮箱账号间用分号分开

3.Python代码

调用Outlook发送邮件,调用Outlook发送邮件,有两种方式:

一是知道邮箱服务器的smtp服务器地址,并有一个邮箱账号和口令,在代码里设置登陆邮箱,发出邮件。

二是单位的电脑已经配置好了,outlook可以直接使用,不知道smtp服务器的地址,而且无法登陆第三方的邮箱系统发送邮件,比如无法通过登陆smtp.163.com,

这种情况下,只能调用本电脑上的outlook。

这里采用第二种方式,参考代码如下:

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

"""
Module 根据定义的Task,发送邮件提醒,避免遗漏处理
""" import os
import xlrd
import schedule
import time
import win32com.client as win32
from datetime import datetime,date dictWeek={0:"Monday",1:"TuesDay",2:"Wednesday",3:"Thursday",4:"Friday",5:"Saturday",6:"Sunday"} def main():
sPath = os.getcwd()
sFile = "Task.xlsx"
sExcelFile = sPath +"\\" + sFile wb = xlrd.open_workbook(filename=sExcelFile) sheet1 = wb.sheet_by_index(0)
nrows1 = sheet1.nrows #注意weekday() 返回的是0-6是星期一到星期日
sWeekday = dictWeek.get(datetime.now().weekday())
sNow = datetime.now() iDay = sNow.day
sToday= formatDay(sNow,"yyyy-mm-dd") for iRow in range(1,nrows1):
sCheck = sheet1.cell(iRow,3).value
if sCheck != "Y":
sFrequency = sheet1.cell(iRow,0).value
s1 = sheet1.cell(iRow,1).value
if sFrequency == "Week":
if s1 == sWeekday:
s2 = sheet1.cell(iRow,2).value
sendEmail(s2)
elif sFrequency == "Day":
               
if s1 == sToday:
s2 = sheet1.cell(iRow,2).value
sendEmail(s2)
elif sFrequency == "Month":
if int(s1) == int(iDay):
s2 = sheet1.cell(iRow,2).value
sendEmail(s2) def formatDay(sDay,sFormat):
sYear = str(sDay.year)
sMonth = str(sDay.month)
sDay = str(sDay.day) if sFormat == "yyyy-mm-dd":
sFormatDay = sYear +"-" +sMonth.zfill(2)+"-" +sDay.zfill(2)
elif sFormatStyle == "yyyy/mm/dd":
sFormatDay = sYear +"/" +sMonth.zfill(2)+"/" +sDay.zfill(2)
else:
sFormatDay = sYear+"-" + sMonth + "-" + sDay return sFormatDay def sendEmail(sTask):
try:
#读取config.txt,获得发送的目标邮箱账号
sConfigFile="config.txt" f=open(sConfigFile,'r')
try:
file_Context=f.read()
except:
return False
finally:
if f:
f.close() outlook = win32.Dispatch('outlook.application')
mail = outlook.CreateItem(0) receivers = [file_Context]
mail.To = receivers[0]
mail.Subject ='这是一封提醒邮件.'
mail.Body="邮件提醒: \r\n 请注意处理任务作业,如已处理可忽略此封邮件。\r\n 任务内容:" + sTask + " \r\n (此邮件由系统自动发送)"
#mail.Attachments.Add('C:\\Users\enegc\\OneDrive - Bayer\\Personal Data\\'+sFileName+'.xlsx')
mail.Send()
return True
except exceptions as e:
return False if __name__ == "__main__":
main()

4.打包Python文件成exe文件,使用pyinstaller

pyinstaller -F -w AutoSendEmail.py

5.部署,把打包好的exe文件从第4步生成的dist文件里拷贝出来,和config.txt以及Task.xlsx文件放到同一个文件夹里,然后在Windows的任务作业里建立一个任务作业,调用

打包好的exe文件,设置成每天执行。

6.上面部署的方式,是利用Windows的定时任务作业调用打包好的exe文件,也可以采用Python自己的任务调度方式,打包成exe后,双击启动,驻留在内存中,由系统自动调用

任务作业。

示例代码如下,这里设置的是每天10:30执行

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

"""
Module 根据定义的Task,发送邮件提醒,避免遗漏处理
""" import os
import xlrd
import schedule
import time
import win32com.client as win32
from datetime import datetime,date dictWeek={0:"Monday",1:"TuesDay",2:"Wednesday",3:"Thursday",4:"Friday",5:"Saturday",6:"Sunday"} def job():
sPath = os.getcwd()
sFile = "Task.xlsx"
sExcelFile = sPath +"\\" + sFile
print("Test")
wb = xlrd.open_workbook(filename=sExcelFile) sheet1 = wb.sheet_by_index(0)
nrows1 = sheet1.nrows #注意weekday() 返回的是0-6是星期一到星期日
sWeekday = dictWeek.get(datetime.now().weekday())
sNow = datetime.now() iDay = sNow.day
sToday= formatDay(sNow,"yyyy-mm-dd") for iRow in range(1,nrows1):
sCheck = sheet1.cell(iRow,3).value
if sCheck != "Y":
sFrequency = sheet1.cell(iRow,0).value
s1 = sheet1.cell(iRow,1).value
if sFrequency == "Week":
if s1 == sWeekday:
s2 = sheet1.cell(iRow,2).value
sendEmail(s2)
elif sFrequency == "Day":
if s1 == sToday:
s2 = sheet1.cell(iRow,2).value
sendEmail(s2)
elif sFrequency == "Month":
if int(s1) == int(iDay):
s2 = sheet1.cell(iRow,2).value
sendEmail(s2) def formatDay(sDay,sFormat):
sYear = str(sDay.year)
sMonth = str(sDay.month)
sDay = str(sDay.day) if sFormat == "yyyy-mm-dd":
sFormatDay = sYear +"-" +sMonth.zfill(2)+"-" +sDay.zfill(2)
elif sFormatStyle == "yyyy/mm/dd":
sFormatDay = sYear +"/" +sMonth.zfill(2)+"/" +sDay.zfill(2)
else:
sFormatDay = sYear+"-" + sMonth + "-" + sDay return sFormatDay def sendEmail(sTask):
try:
#读取config.txt,获得发送的目标邮箱账号
sConfigFile="config.txt" f=open(sConfigFile,'r')
try:
file_Context=f.read()
except:
return False
finally:
if f:
f.close() outlook = win32.Dispatch('outlook.application')
mail = outlook.CreateItem(0) receivers = [file_Context]
mail.To = receivers[0]
mail.Subject ='这是一封提醒邮件.'
mail.Body="邮件提醒: \r\n 请注意处理任务作业,如已处理可忽略此封邮件。\r\n 任务内容:" + sTask + " \r\n (此邮件由系统自动发送)"
#mail.Attachments.Add('C:\\Users\enegc\\OneDrive - Bayer\\Personal Data\\'+sFileName+'.xlsx')
mail.Send()
return True
except exceptions as e:
return False schedule.every().day.at("10:30").do(job) while True:
schedule.run_pending()
time.sleep(1)

代码参考,已分享在百度网盘上。

链接:https://pan.baidu.com/s/1KMKVmpEyuA3zI0lEhfon7A
提取码:dzi9

日期:2019-07-03

Python自定义任务发邮件提醒的更多相关文章

  1. EDM营销算法:python自动批量发邮件

    EDM营销:全称Email Direct Marketing,即电子邮件营销.企业可以通过使用EDM软件向目标客户发送EDM邮件,建立同目标顾客的沟通渠道,向其直接传达相关信息,用来促进销售.EDM软 ...

  2. python连接数据库自动发邮件

    python连接数据库实现自动发邮件 1.运行环境 redhat6 + python3.6 + crontab + Oracle客户端 2.用到的模块  3.操作步骤 (1)安装python3.6参考 ...

  3. 脚本监控web服务器,工作不正常发邮件提醒

    背景介绍公司有多个web网站,没有配置监控服务,每天都需要定时检查服务器是否工作正常.低效耗时. 代码片段 #!/bin/bash # Author Jerry.huang (Email:Jerry. ...

  4. python实现自动发邮件

    Python有两个内置库:smtplib和email,可以实现邮件功能,无需下载,直接import导入. smtplib库负责发送邮件 Email库负责构造邮件格式和内容 邮件发送需要遵守SMTP协议 ...

  5. 调magento自定义模板发邮件

    1. 设置邮件模板 <global> <template> <email> <custom_email_template1 module="Samp ...

  6. python之smtplib发邮件

    第一版: 认证发信,不支持附件 #!/usr/bin/env python # --------------------------------------- # author : Geng Jie ...

  7. Python学习笔记——发邮件

    参考:Python3实现163邮箱SMTP发送邮件 1.首先需要注册一个网易的邮箱,开启smtp服务,并使用其授权码 2.发送邮件的Python脚本 #!/usr/bin/python # -*- c ...

  8. 【python】使用python smtplib库发邮件添加cc,bcc

    #!/usr/bin/env python# -*- coding: utf-8 -*- '''@author@mail @date 2017/03/16 发送邮件'''import smtplibf ...

  9. python使用SMTP发邮件时使用Cc(抄送)和Bcc(密送)

    SMTP发送邮件的时候,并没有特殊的通信语句告诉邮件服务器 谁是主送,谁是抄送/密送,这三个角色都是以同样的方式告诉邮件服务器的,然后重点在邮件内容里. 邮件内容分为头和体两部分(就像http),头部 ...

随机推荐

  1. 手把手教你如何构建Vue前端组件库

    在前端开发中可能会遇到将相同的功能模板集合成一个组件,供他人调用,这样可以减少重复造轮子,也可以节约人力.财力,更能够提高代码的可维护度:下面将通过详细的步骤教你如何构建一个Vue前端组件. 1.在本 ...

  2. 等差数列,for循环,递归和尾递归的对比

    生活中,如果1+2+3+4.....+100,大家基本上都会用等差数列计算,如果有人从1开始加,不是傻就是白X,那么程序中呢,是不是也是这样.今天无意中看到了尾递归,以前也写过,但是不知道这个专业名词 ...

  3. 【python基础语法】数据类型:数值、字符串 (第2天课堂笔记)

    """ 数据类型: 一.数值类型:整数 浮点数 布尔值 二.序列类型:字符串.列表 元祖 三.散列类型:字典 集合 可变数据类型: 列表 字典 集合,可以改动内存地址数据 ...

  4. K8S 概述

    K8S------概述 K8S,就是基于容器的集群管理平台,它的全称,是kubernetes.Kubernetes 这个单词来自于希腊语,含义是舵手或领航员.K8S是它的缩写,用“8”字替代了“ube ...

  5. 字节跳动挤上少儿英语末班车,gogokid能否抵达终点?

    编辑 | 于斌 出品 | 于见(mpyujian) 近日,据多方消息,字节跳动旗下少儿英语品牌gogokid,迎来了一位新的90后CEO金钱琛.据知情人士透露,金钱琛入职不到两个月,目前全面掌管gog ...

  6. 动手实现一个同步器(AQS)

    在多线程情景下,如果不会某一共享变量采取一些同步机制,很可能发生数据不安全现象,比如购买车票时,当多个人购买时,不加锁就会产生多人买同一张票的现象,显然这是不可取的.所以要有一种同步机制,在某一时刻只 ...

  7. MVC开发模式以及Smarty模板引擎的使用

    Linux 全局安装 composer 将目录切换到/usr/local/bin/目录 cd /usr/local/bin/ 在 bin 目录中下载 composer curl -sS https:/ ...

  8. 什么是json? 什么是xml?JSON与XML的区别比较

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它使得人们很容易的进行阅读和编写.同时也方便了机器进行解析和生成.它是基于 JavaScript Prog ...

  9. ECMAScript基本对象——RegExp 正则表达式对象

    含义:定义字符串的组成规则 使用: 1.定义单个字符:[ ] [a] 表示有一个字符是  小写的a [ab] 表示有一个字符是  小写的a或者b [a-z] 表示有一个字符是  小写的a到z [a-z ...

  10. 学习django3过程中的坑

    最近跟着Django by Example 2015学习,可老想用最新版的Django3.在学的过程中可踩了不少坑. 今天就又碰到一个: 在这本书中96页有这样的代码: url(r'^login/$' ...