热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python:获取“3年前的今天”的日期时间

原文链接:Python:获取“3年前的今天”的日期时间Python:getdatetimefor3yearsagotoday在Python中,如何获取3年前的今天的datetime

原文链接:


Python:获取“ 3年前的今天”的日期时间

Python: get datetime for '3 years ago today'

在Python中,如何获取" 3年前的今天"的datetime对象?

更新:FWIW,我不太在乎准确性……也就是说,今天是2月29日,我不在乎我的答案是2月28日还是3月1日。 在这种情况下,简洁比可配置性更重要。

 相关讨论



  • 如何创建等于15分钟前的DateTime的可能重复项?

  • 大概是今天的3月1日,无论之间是否有a年,您都想获得3月1日? 我认为所有现有的答案在这方面都失败了。

  • 几乎但不完全:不变的15分钟与没有变化的3年之间的差异是巨大的。

  • @Jason我同意你的观点,尽管从OP的编辑看来,他似乎并不太担心,所以这样的话将是重复的。

  • 当人们接受明显不正确的答案时,此站点确实需要社区替代的方法。 3 * 365天不是3年,并且在那里有正确的答案。

  • @Glenn Maynard-您可以编辑标题。 因为他真的不想要3年前。

如果需要精确,请使用dateutil模块来计算相对日期:

from datetime import datetime
from dateutil.relativedelta import relativedelta
three_yrs_ago
= datetime.now() - relativedelta(years=3)


  • 感谢您的准确性。即使OP不在乎准确性,其他人也可能会。

import datetime
datetime.datetime.now()
- datetime.timedelta(days=3*365)


  • (-1)这显然是错误的,因为它不处理leap年。

  • AP257说:"我不太在乎准确性"。我解释为"我不在乎leap年"

  • @Diniz:您将其解释为"我想错了"。做到这一点是如此容易,做错它只是愚蠢的,当有正确答案时,就很奇怪地接受这个答案。

  • 提问者明确告诉相反的情况时,给出一个不太简洁但更准确的答案是否正确?

  • +1为简单起见。也许OP只是想举一个总体上如何做这样的例子。

  • 这有点草率。

  • 感谢您的简单性。我也不在乎准确性。无论如何,我实际上一直在寻找不同的日子。

  • 对于"我不太在乎准确性"给出的示例表明,提问者实际上并未充分考虑问题。该示例并不关心2月29日变为2月28日还是3月1日,但是此代码可以(通常将)执行将3月5日转换为3月6日的操作。不关心第一件事的人可能仍然会关心第二件事。 。

  • 如果您特别关心地球在轨道上的位置,则可以通过乘以365.2422来精确地处理leap年。

  • 减去365 * 3天当然是错误的-您跨越crossing年的时间超过一半。


dt datetime.now()
dt = dt.replace(year=dt.year-3)
# datetime.datetime(2008, 3, 1, 13, 2, 36, 274276)

ED:为了正确地解决the年问题,

def subtract_years(dt, years):
try:
dt
= dt.replace(year=dt.year-years)
except ValueError:
dt
= dt.replace(year=dt.year-years, day=dt.day-1)
return dt


  • 我认为这是经常被忽视的事情。

  • 好吧,现在您还有另一个问题:datetime.datetime(2008,2,29).replace(year=2005) -> ValueError。捕捉到该错误并减去一整天,我认为它仍然更加准确。

  • @Jochen:是的,很简单。

  • 我一直忘了replace。它比我的解决方案更简单。

  • @Mark:我也刚开始做过;我最初做的是你做的。不过,该网站似乎在该版本的编辑历史记录中放错了该版本。

  • 2100年后会发生什么?

def add_years(dt, years):
try:
result
= datetime.datetime(dt.year + years, dt.month, dt.day, dt.hour, dt.minute, dt.second, dt.microsecond, dt.tzinfo)
except ValueError:
result
= datetime.datetime(dt.year + years, dt.month, dt.day - 1, dt.hour, dt.minute, dt.second, dt.microsecond, dt.tzinfo)
return result
>>> add_years(datetime.datetime.now(), -3)
datetime.datetime(
2008, 3, 1, 12, 2, 35, 22000)
>>> add_years(datetime.datetime(2008, 2, 29), -3)
datetime.datetime(
2005, 2, 28, 0, 0)

尽管使用dateutil的答案很好,但是另一种方法是在PyPI上使用pendulum包。有关更多信息,请参阅其文档。

>>> import pendulum
>>> dt = pendulum.now().subtract(years=3)
>>> dt
DateTime(
2015, 10, 5, 17, 44, 41, 82598, tzinfo=Timezone('America/New_York'))
>>> type(dt)
pendulum.datetime.DateTime

如果您需要当前日期时间来进一步使用,则可能应该先将pendulum.now()保存到变量中,然后再使用该变量!

如果您确实想避免时区,请使用.naive()。

您不需要将结果转换为原生Python对象,但是如果确实需要,一种实现方法是:

>>> import datetime
>>> pydt = datetime.datetime.fromisoformat(dt.isoformat())
>>> pydt
datetime.datetime(
2015, 10, 5, 17, 44, 41, 82598, tzinfo=datetime.timezone(datetime.timedelta(days=-1, secOnds=72000)))
>>> type(pydt)
datetime.datetime

看不到它,它非常简单明了,

In [1]: import datetime
In [2]: dt datetime.datetime.today()
In [3]: datetime.datetime(year=dt.year-3, month=dt.month, day=dt.day)
Out[3]: datetime.datetime(201641100)

为什么不简单在替换年份之前检查a年。
这不需要任何额外的程序包或try:Except。

def years_ago(dt, years):
if dt.mOnth== 2 and dt.day == 29:
dt
= dt.replace(day=28)
return dt.replace(year=dt.year - years)

In [3]: import datetime as dt
In [
4]: today=dt.date.today()
In [
5]: three_years_ago=today-dt.timedelta(days=3*365)
In [
6]: three_years_ago
Out[
6]: datetime.date(2008, 3, 1)

 



推荐阅读
  • 优化SQL Server批量数据插入存储过程的实现
    本文介绍了一种改进的SQL Server存储过程,用于生成批量插入语句。该方法不仅提高了性能,还支持单行和多行模式,适用于SQL Server 2005及以上版本。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本文探讨了使用C#在SQL Server和Access数据库中批量插入多条数据的性能差异。通过具体代码示例,详细分析了两种数据库的执行效率,并提供了优化建议。 ... [详细]
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文详细探讨了 Django 的 ORM(对象关系映射)机制,重点介绍了其如何通过 Python 元类技术实现数据库表与 Python 类的映射。此外,文章还分析了 Django 中各种字段类型的继承结构及其与数据库数据类型的对应关系。 ... [详细]
  • 探讨如何从数据库中按分组获取最大N条记录的方法,并分享新年祝福。本文提供多种解决方案,适用于不同数据库系统,如MySQL、Oracle等。 ... [详细]
  • 解析SQL查询结果的排序问题及其解决方案
    本文探讨了为什么某些SQL查询返回的数据集未能按预期顺序排列,并提供了详细的解决方案,帮助开发者理解并解决这一常见问题。 ... [详细]
  • 本文介绍 SQL Server 的基本概念和操作,涵盖系统数据库、常用数据类型、表的创建及增删改查等基础操作。通过实例帮助读者快速上手 SQL Server 数据库管理。 ... [详细]
  • MySQL中的日期格式转换函数:STR_TO_DATE与DATE_FORMAT
    本文详细介绍了MySQL中用于日期格式转换的两个重要函数:STR_TO_DATE和DATE_FORMAT。通过具体示例,帮助读者更好地理解和应用这些函数。 ... [详细]
  • Django 使用slug field时遇到的问题 ... [详细]
author-avatar
cws401_712
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有