python 日期相关的各种操作总结

转载 2013年12月04日 11:40:30
用 Python 做项目时,经常会遇到与日期转换相关,日期计算相关的功能,动不动就要去查python手册,感觉麻烦,因此把自己常用的一些东西,总结了一下,总体说来到目前为止遇到如下一些需求:
1. 用python 把datetime转成字符串
2. 用python 把字符串转成datetime
3. 用python 把字符串转成时间戳形式
4. 用python 把时间戳转成字符串形式
5. 用python 把把datetime类型转外时间戳形式
6. 用python 计算两个日期之间的差
7. 用python 计算两个日期的 timestamp 差值
8. 用python 比较两个日期的大小
9. 指定日期加上 一个时间段,天,小时,或分钟之后的日期 

下面是测试代码:

#coding:utf-8
'''
base on python 2.7
Created on 2012-12-14
@author: yiahomen.com
'''
import datetime
import time

def datetime_toString(dt):
    """把datetime转成字符串"""
    return dt.strftime("%Y-%m-%d")

def string_toDatetime(string):
    """把字符串转成datetime"""
    return datetime.datetime.strptime(string, "%Y-%m-%d")

def string_toTimestamp(strTime):
    """把字符串转成时间戳形式"""
    return time.mktime(string_toDatetime(strTime).timetuple())

def timestamp_toString(stamp):
    """把时间戳转成字符串形式"""
    return time.strftime("%Y-%m-%d-%H", time.localtime(stamp))

def datetime_toTimestamp(dateTime):
    """把datetime类型转外时间戳形式"""
    return time.mktime(dateTime.timetuple())

def substract_DateTime(dateStr1,dateStr2):
    """ 返回两个日期之间的差 """
    d1=string_toDatetime(dateStr1)
    d2=string_toDatetime(dateStr2)
    return d2-d1

def substract_TimeStamp(dateStr1,dateStr2):
    """ 两个日期的 timestamp 差值 """
    ts1= string_toTimestamp(dateStr1)
    ts2= string_toTimestamp(dateStr2)
    return ts1-ts2

def compare_dateTime(dateStr1,dateStr2):
    """两个日期的比较, 当然也可以用timestamep方法比较,都可以实现."""
    date1 = string_toDatetime(dateStr1)
    date2 = string_toDatetime(dateStr2)
    return date1.date()>date2.date()

def dateTime_Add(dateStr,days=0,hours=0,minutes=0):
    """ 指定日期加上 一个时间段,天,小时,或分钟之后的日期 """
    date1= string_toDatetime(dateStr)
    return date1+datetime.timedelta(days=days,hours=hours,minutes=minutes)

if __name__=='__main__':
    print substract_DateTime('2012-12-12','2012-01-01')
    #-346 days, 0:00:00
    print substract_DateTime('2012-12-12','2012-01-01').days
    #-346
    print substract_TimeStamp('2012-12-12','2012-01-01')
    #29894400.0    
    print substract_TimeStamp('2012-12-12','2012-01-01')/(24*60*60),'天'
    #346.0 天
    print compare_dateTime('2012-12-12','2012-01-01')
    #True
    print dateTime_Add('2012-12-12',days=10,hours=5,minutes=10)
    #2012-12-22 05:10:00

相关文章推荐

mysql 日期函数相关操作

  • 2010年05月13日 14:18
  • 9KB
  • 下载

sql 日期相关操作

1.DECLARE @Date DATETIME SET @Date = GETDATE () -- 前一天,给定日期的前一天 SELECT DATEADD ( DAY , - 1 , @Date )...

c++日期和时间相关操作-<time.h>(ctime)

time.h(ctime)是c time library,定义了获取和操作日期和时间的函数。 1. 结构 typedef long time_t;time_t是长整型,表示的是距(1970年,1月1...
  • whuqin
  • whuqin
  • 2013年01月04日 11:48
  • 12316

openerp学习笔记 日期时间相关操作

openerp学习笔记 日期时间相关操作 日期格式化字符串:DATE_FORMAT = "%Y-%m-%d" 日期时间格式字符串:DATETIME_FORMAT = "%Y-%m-...

日期Date操作的相关方法

package com.cmcc.flow.util; import org.apache.commons.logging.Log; import org.apache.commons.loggin...
  • CHBSRZF
  • CHBSRZF
  • 2015年09月02日 14:25
  • 100

SOQL数据查询时对日期的相关处理操作。

一. 日期相关处理函数  在数据查询中,我们很多时候需要通过日期进行数据过滤。这时,使用soql的函数或者常量操作会更加便捷。主要函数和常量如下:  CALENDAR_YEAR(field...

objective-C日期相关操作

1、获取当前日期、时间     NSDate *currentDate = [NSDate date];     NSDateFormatter *dateFormatter = [[NSDa...

Javascript 日期格式化 相关操作

Javascript 日期时间相关操作

Python基础、函数及其相关函数库(Numpy、TensorFlow)常用函数集锦(更新中,更新日期:2017-08-03)

更新记录: 2017-07-09 2017-07-12 2017-07-13Python函数参考资料: 1.Python基础教程 2.Python学习与分享平台 3.Python 3.6.2rc...

python操作excel相关模块

  • 2011年04月19日 02:23
  • 12.58MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:python 日期相关的各种操作总结
举报原因:
原因补充:

(最多只允许输入30个字)