【python】自动化办公之定时发送邮件实战详解(apscheduler+smtplib+prettytable)

本文主要是介绍【python】自动化办公之定时发送邮件实战详解(apscheduler+smtplib+prettytable),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上班狗每天都有些重复性的工作,单凭脑子记实在不靠谱。本想用微信发提醒,无奈被禁用了,只能写个脚本发邮件实现了。

需求

邮件提醒,小组四人每周轮岗工作,定时每星期一到星期五早8点55分。

思路

  1. send_email():发送邮件。1)SMTP服务器地址。2)发件人的用户名密码。3)收件人的用户名。通过获取当前时间位于今年第几周,除以4取余来定位轮岗人的邮箱。4)邮件标题。5)邮件内容。6)连接、登录、发送、关闭
  2. 定时执行。

脚本

#!/usr/bin/env python3
#coding=utf-8import time,os,unittest
import sys
from email.mime.text import MIMEText
import smtplib
import datetime
import schedule
from apscheduler.schedulers.blocking import BlockingSchedulerdef send_email():
"发送邮件"smtpserver = 'smtp.exmail.qq.com'user_f = 'summer@***.com'pwd_f = '******'# 当前时间是今年第几周,除以4给不同人发邮件i = datetime.datetime.now().isocalendar()[1]%4print(i)if i == 0 :user_r = 'xiaoming@***.com'elif i == 1 :user_r = 'xiaohong@***.com'elif i  == 2:user_r = 'xiaolan@***.com'elif i  == 3:user_r = 'xiaohua@***.com'else:user_r = 'admin@***.com'now = datetime.datetime.now().strftime('%Y%m%d') #减一天 now = (datetime.datetime.now()+datetime.timedelta(days=-1)).strftime('%Y%m%d') subject = '工作提醒'+nowmsg = MIMEText('检查工作巴拉巴拉','plain','utf-8') #邮件内容msg['From'] = user_f #用户名msg['To'] = pwd_f #密码msg['Subject'] = subject #标题server = smtplib.SMTP()server.connect(smtpserver,25) # SMTP协议默认端口是25server.set_debuglevel(1)server.login(user_f,pwd_f)server.sendmail(user_f,user_r,msg.as_string())server.quit()def job():send_email()schedule.every().day.at('8:55').do(job)  while True:schedule.run_pending()time.sleep(60)if __name__ == '__main__':scheduler = BlockingScheduler()# 定时执行,星期一到星期五,早上8点55,直到2021年1月1日结束scheduler.add_job(func=send_email,trigger='cron', day_of_week='mon-fri', hour=8, minute=55, end_date='2021-01-01')scheduler.start()        

注意

以上脚本在本地或主机上运行皆可。但在主机上运行需要注意:

  1. 第一行定义环境变量,python3的路径,因为主机上python2为默认版本,所以特此声明。 #!/usr/bin/env python3,执行时直接./文件名即可。
  2. 第二行定义编码,因为有汉字所以要定义utf8类型,必须放在第二行 #coding=utf-8

扩展

如果邮件内容为列表类型,输出美化表格效果会更好,下面介绍prettytable表格美化包。

from prettytable import PrettyTable
from prettytable import MSWORD_FRIENDLYdef pretty_info(task_list):#   默认表头:Field 1、Field 2...#   添加表头table = PrettyTable(["用户", "状态", "任务id", "任务名称"])#   add_row 添加一行数据for task in task_list:table.add_row(task)#   默认居中对齐#   设置"值"列,局左对齐 left首字母table.align["任务名称"] = 'l'table.set_style(MSWORD_FRIENDLY)print(table)#   输出HTML类型return table.get_html_string()

在发送邮件时只需把msg内容格式换成html类型。

msg = MIMEText(lists, 'html', 'utf-8')

结果
在这里插入图片描述
在这里插入图片描述

相关文章:【python】自动化办公之excel入GP库实战详解(xlwings+psycopg2)

这篇关于【python】自动化办公之定时发送邮件实战详解(apscheduler+smtplib+prettytable)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/539323

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

MyBatis常用XML语法详解

《MyBatis常用XML语法详解》文章介绍了MyBatis常用XML语法,包括结果映射、查询语句、插入语句、更新语句、删除语句、动态SQL标签以及ehcache.xml文件的使用,感兴趣的朋友跟随小... 目录1、定义结果映射2、查询语句3、插入语句4、更新语句5、删除语句6、动态 SQL 标签7、ehc

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符