zoukankan      html  css  js  c++  java
  • Django的datetime.timedelta类(Django编程-2)

    datetime.timedelta对象代表两个时间之间的时间差,两个date或datetime对象相减就可以返回一个timedelta对象。
    如果有人问你昨天是几号,这个很容易就回答出来了。但是如果问你200天前是几号,就不是那么容易答出来。而在Python中datetime模块中的timedelta就可以很轻松给出答案。
    函数原型:
    class datetime.timedelta([days[, seconds[, microseconds[, milliseconds[, minutes[, hours[, weeks]]]]]]])
    从构造函数的定义中可以看出,所有参数都是可选的,并且默认都是0。参数的值可以是整数,浮点数,正数或负数。timedelta也有自己的一些属性和方法,可以通过dir(datetime.timedelta)查看。针对时间存储,timedelta内部只能存储days,seconds,microseconds,其他参数的值会自动按如下规则进行转换:

    1 millisecond(毫秒)转换成 1000 microseconds(微秒)
    1 minute 转换成 60 seconds
    1 hour 转换成 3600 seconds
    1 week转换成 7 days

    一、两个datetime.datetime类型相减 或两个 datetime.date类型相减 的结果就是datetime.timedelta类型

    二、以下是具体使用方法

    • 1、以下是打印一天后的时间
    now=datetime.datetime.now() 
    now 
    datetime.datetime(2018, 1, 20, 11, 5, 18, 227000) 
    delta=datetime.timedelta(days=1) 
    delta 
    datetime.timedelta(1) 
    newtime=now+delta 
    print newtime 
    2018-01-21 11:05:18.227000 
    newtime 
    datetime.datetime(2018, 1, 21, 11, 5, 18, 227000) 
    str(newtime) 
    ‘2018-01-21 11:05:18.227000’ 
    str(newtime)[:-7] 
    ‘2018-01-21 11:05:18’ 
    print newtime.strftime(“%Y-%m-%d %H:%M:%S”) 
    2018-01-21 11:05:18
    
    • 2、以下是得到1天前的时间,还有一种
    now=datetime.datetime.now() 
    now-datetime.timedelta(days=1) 
    datetime.datetime(2018, 1, 19, 11, 22, 11, 774000) 
    now+datetime.timedelta(days=-1) 
    datetime.datetime(2018, 1, 19, 11, 22, 11, 774000) 
    now 
    datetime.datetime(2018, 1, 20, 11, 22, 11, 774000)
    
    • 3、以下是得到3小时前的时间
    now=datetime.datetime.now() 
    now-datetime.timedelta(hours=3) 
    datetime.datetime(2018, 1, 20, 8, 14, 45, 545000)
    
    • 4、以下是得到3小时30分钟前的时间
    now 
    datetime.datetime(2018, 1, 20, 11, 14, 45, 545000) 
    now-datetime.timedelta(hours=3,minutes=30) 
    datetime.datetime(2018, 1, 20, 7, 44, 45, 545000)
    
    • 5、以下是得到3小时30秒前的时间
    now 
    datetime.datetime(2018, 1, 20, 11, 14, 45, 545000) 
    now-datetime.timedelta(hours=3,seconds=30) 
    datetime.datetime(2018, 1, 20, 8, 14, 15, 545000)
    
    • 6、以下是得到3天3小时30秒前的时间
    now-datetime.timedelta(hours=3,seconds=30,days=3) 
    datetime.datetime(2018, 1, 17, 8, 14, 15, 545000)
    
    • 7、以下是得到总秒数,类型是float型
    datetime.timedelta(hours=3,seconds=22).total_seconds() 
    10822.0 
    3*60*60+22 
    10822 
    type(datetime.timedelta(hours=3,seconds=22).total_seconds()) 
    
  • 相关阅读:
    表的管理
    子查询
    sql语句
    基本sql语句与oracle函数
    Visual C# 2008+SQL Server 2005 数据库与网络开发6.1.1 报表服务概述
    Visual C# 2008+SQL Server 2005 数据库与网络开发 5.4 小结
    Visual C# 2008+SQL Server 2005 数据库与网络开发5.3.1 日期时间函数
    Visual C# 2008+SQL Server 2005 数据库与网络开发 5.3 函数
    Visual C# 2008+SQL Server 2005 数据库与网络开发第6章 数据报表
    Visual C# 2008+SQL Server 2005 数据库与网络开发5.2.2 GROUP BY
  • 原文地址:https://www.cnblogs.com/kadycui/p/10654680.html
Copyright © 2011-2022 走看看