一、需求

现在有一个场景,需要每月的最后一天,发送一封邮件。

二、获取本月最后一天

有没有办法使用Python的标准库轻松确定(即一个函数调用)给定月份的最后一天?

答案是有的,使用 datetime 就可以实现

#!/usr/bin/env python
# coding: utf-8 import datetime def last_day_of_month(any_day):
"""
获取获得一个月中的最后一天
:param any_day: 任意日期
:return: string
"""
next_month = any_day.replace(day=28) + datetime.timedelta(days=4) # this will never fail
return next_month - datetime.timedelta(days=next_month.day) # 注意: 年月日,这些变量必须是数字,否则报错!
year = 2019 # 年
month = 5 # 月
day = 16 # 日 res = last_day_of_month(datetime.date(year, month, day))
print(res)

执行输出:

2019-05-31

判断当天是否为月末

#!/usr/bin/env python3
# coding: utf-8 import datetime def last_day_of_month(any_day):
"""
获取获得一个月中的最后一天
:param any_day: 任意日期
:return: string
"""
next_month = any_day.replace(day=28) + datetime.timedelta(days=4) # this will never fail
return next_month - datetime.timedelta(days=next_month.day) # 当前日期
now = datetime.datetime.now().date()
year,month,day = str(now).split("-") # 切割
# 年月日,转换为数字
year = int(year)
month = int(month)
day = int(day) # 获取这个月最后一天
last_day = last_day_of_month(datetime.date(year, month, day)) # 判断当前日期是否为月末
if str(now) == last_day:
print('yes')
else:
print('no')

执行输出:

no

三、发送邮件

发送邮件部分,参考链接:

https://www.cnblogs.com/xiao987334176/p/10022026.html

代码结构

./
├── send_mail.py
└── alert.py

send_mail.py

#!/usr/bin/env python3
# coding: utf-8
"""
发送邮件
""" import sys
import smtplib # 加载smtplib模块
from email.mime.text import MIMEText
from email.utils import formataddr class SendMail(object):
def __init__(self, sender, title, content):
self.sender = sender # 发送地址
self.title = title # 标题
self.content = content # 发送内容
self.sys_sender = '123456@163.com' # 系统账户
self.sys_pwd = '' # 系统账户密码 def send(self):
try:
"""
构造一个邮件对象,
第一个参数就是邮件正文,
第二个参数是MIME的subtype,传入'html',最终的MIME就是'text/html'。
最后一定要用utf-8编码保证多语言兼容性。
"""
msg = MIMEText(self.content, 'html', 'utf-8')
# 发件人格式
msg['From'] = formataddr(["IT事业部系统", self.sys_sender])
# 收件人格式
msg['To'] = formataddr(["", self.sender])
# 邮件主题
msg['Subject'] = self.title
# SMTP服务器
server = smtplib.SMTP("smtp.163.com", 25)
# 登录账户
server.login(self.sys_sender, self.sys_pwd)
# 发送邮件
server.sendmail(self.sys_sender, [self.sender, ], msg.as_string())
# 退出账户
server.quit()
return True
except Exception as e:
print(e)
return False if __name__ == '__main__':
# 参数个数,由于sys.argv[0]就是脚本名,所以要减1
num = len(sys.argv) - 1
if num < 3 or num > 3:
exit("参数错误,必须传3个参数!当前参数个数为%s" % num) sender = sys.argv[1] # 发送地址
title = sys.argv[2] # 标题
content = sys.argv[3] # 发送内容 # 调用send方法,发送邮件
ret = SendMail(sender, title, content).send()
if ret:
print('发送成功!')
else:
print('发送失败!')

alert.py

#!/usr/bin/env python3
# coding: utf-8
"""
月末发送一封邮件
""" import datetime
from send_mail import SendMail class AlertServices(object):
def __init__(self):
pass def last_day_of_month(self,any_day):
"""
获取获得一个月中的最后一天
:param any_day: 任意日期
:return: string
"""
next_month = any_day.replace(day=28) + datetime.timedelta(days=4) # this will never fail
return next_month - datetime.timedelta(days=next_month.day) def main(self):
"""
主程序
:return:
""" # 当前日期
now = datetime.datetime.now().date()
year,month,day = str(now).split("-") # 切割
# 年月日,转换为数字
year = int(year)
month = int(month)
day = int(day) # 获取这个月最后一天
last_day = self.last_day_of_month(datetime.date(year, month, day)) # 判断当前日期是否为月末
if str(now) != last_day:
print("不是月末")
return False # 发送邮件
sender = "12345678@qq.com" # 发送地址
title = "月末提醒" # 标题
content = "还不快点写报告" # 发送内容 # 调用send方法,发送邮件
ret = SendMail(sender, title, content).send()
if ret:
print('发送成功!')
else:
print('发送失败!') if __name__ == '__main__':
# 执行主程序
AlertServices().main()

执行 alert.py,输出:

不是月末

任务计划

定义Linux任务计划,每天早上9点执行一次。

0 9 * * * root /usr/bin/python3 /opt/alert/alert.py

本文参考链接:

https://cloud.tencent.com/developer/ask/188186

Python 获取本月的最后一天的更多相关文章

  1. java获取本月开始时间和结束时间、上个月第一天和最后一天的时间以及当前日期往前推一周、一个月

    import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; import java.uti ...

  2. java获取本月第一天和最后一天

    public class CalendarTest { public static void main(String[] args) { // 获取当前年份.月份.日期 Calendar cale = ...

  3. Sybase:获取本月最后一天的日期的实现方法

    Sybase:获取本月最后一天的日期的实现方法 Oracle中查询月底那天的日期的函数为:last_day(). 在ASE中没有对应的函数,在Oracle移植到Sybase的时候,需要手动编写函数来实 ...

  4. moment.js(moment-in-node.js)获取本月最后一天 不指定

    http://tommyhu.cn/moment-in-nodejs/ //获取本月最后一天 to=using.moment(日期).endOf('month').format("YYYY- ...

  5. [python实用代码片段]python获取当前时间的前一天,前一周,前一个月

    python获取当前时间的前一天,前一周,前一个月. 实用python的datetime.timedelta方法,避免了有的月份是30和31等不同的情况. 获取前一个月的时间,方法实现:首先datet ...

  6. [Java] 获取本月周次和日期时间段信息

    package com.wdcloud.monitoring.common; import java.text.SimpleDateFormat; import java.util.ArrayList ...

  7. mysql日期 获取本月第一天 获取下个月的第一天

    --获取当前日期 select curdate(); --获取当月最后一天 select last_day(curdate()); --获取本月第一天 select DATE_ADD(curdate( ...

  8. MySQL 获取本月第一天、下个月第一天等

    select curdate(); --获取当前日期 select last_day(curdate()); --获取当月最后一天. select DATE_ADD(curdate(),interva ...

  9. 使用shell/python获取hostname/fqdn释疑

    一直以来被Linux的hostname和fqdn(Fully Qualified Domain Name)困惑了好久,今天专门抽时间把它们的使用细节弄清了. 一.设置hostname/fqdn 在Li ...

随机推荐

  1. (12)Go面向对象

    尽管Go中没有封装.继承.多态这些概念,但可以通过别的方式实现这个特性: *封装:通过方法实现 *继承:通过匿名字段实现 *多态:通过接口实现 package main import "fm ...

  2. 阿里云服务器安装配置配置MySQL

    1.先更新软件 输入 yum -y update 2.下载MySql安装包 rpm -ivh http://dev.mysql.com/get/mysql57-community-release-el ...

  3. Mysql问题1862

    使用Navicat连接MySQL数据库出现1862错误(1862:Your password has expired.To log in you must change it change it us ...

  4. #C++初学记录ACM补题(D. Candies!)前缀和运算。

    D - Candies!   Consider a sequence of digits of length [a1,a2,-,a]. We perform the following operati ...

  5. photoshop 的安装破解

    最近学习需要用到photoshop,但是photoshop试用期只有30天,于是尝试破解photoshop.参考了网上的很多博客,失败了好几次,终于找到一篇靠谱的博客,很顺利的成功了.在这里记录一下, ...

  6. tomcat启动慢的解决办法

    SessionIdGeneratorBase.createSecureRandom Creation of SecureRandom instance for session ID generatio ...

  7. python 图片格式转换png转jpg,如何利用python给图片添加半透明水印

    from PIL import Imageim = Image.open(r'd:\test2.png')r, g, b, a = im.split()im = Image.merge("R ...

  8. ASP.NET与非托管DLL的那些事儿【转+增】

    https://www.cnblogs.com/yeahgis/archive/2011/11/12/2246341.html ASP.NET与非托管DLL的那些事儿 环境VS2010 语言:ISO ...

  9. dubbo、zookeeper心跳相关参数解析与测试

    dubbo consumer和provider的心跳机制 dubbo客户端和dubbo服务端之间存在心跳,目的是维持provider和consumer之间的长连接.由dubbo客户端主动发起,可参见d ...

  10. Oracle系列五 多表查询

    笛卡尔集笛卡尔集会在下面条件下产生: 省略连接条件 连接条件无效 所有表中的所有行互相连接 为了避免笛卡尔集, 可以在 WHERE 加入有效的连接条件. Oracle 连接 使用连接在多个表中查询数据 ...