time 모듈에 비해 datetime 모듈의 인터페이스가 더 직관적이고 호출하기 쉽습니다. 오늘은 datetime 모듈에 대해 이야기해 보겠습니다.
datetime 모듈은 datetime이 나타낼 수 있는 최소 및 최대 연도를 각각 나타내는 datetime.MINYEAR 및 datetime.MAXYEAR라는 두 가지 상수를 정의합니다. 그 중 MINYEAR = 1, MAXYEAR = 9999입니다. (가끔 플레이하시는 분들은 이 범위면 충분합니다~~)
datetime 모듈은 다음과 같은 클래스를 정의합니다.
•datetime.date: 날짜를 나타내는 클래스입니다. 일반적으로 사용되는 속성에는 연도, 월, 일이 포함됩니다.
•datetime.time: 시간을 나타내는 클래스입니다. 일반적으로 사용되는 속성에는 시, 분, 초, 마이크로초가 포함됩니다.
•datetime.datetime: 날짜 및 시간을 나타냅니다.
•datetime.timedelta: 시간 간격, 즉 두 시점 사이의 길이를 나타냅니다.
•datetime.tzinfo: 시간대 관련 정보입니다. (이 클래스는 여기에서 자세히 논의되지 않습니다. 관심 있는 어린이는 Python 매뉴얼을 참조할 수 있습니다.)
참고: 위의 객체 유형은 모두 불변입니다.
다음은 이러한 클래스를 사용하는 방법을 자세히 설명합니다.
date class
date class는 날짜를 나타냅니다. 날짜는 연, 월, 일로 구성됩니다(지구상 사람들은 다 아시죠~~). 날짜 클래스의 생성자는 다음과 같습니다.
class datetime.date(year, Month, day): 매개변수의 의미에 대해서는 자세히 설명하지 않지만 몇 가지 주의할 점이 있습니다.
• 연도 범위는 [MINYEAR, MAXYEAR], 즉 [1, 9999]입니다.
·월의 범위는 [1, 12]입니다. (월은 0~_~이 아닌 1부터 시작합니다.)
•일의 최대값은 주어진 연도 및 월 매개변수에 따라 결정됩니다. 예를 들어, 윤년의 2월은 29일입니다.
날짜 클래스는 작업을 용이하게 하기 위해 일반적으로 사용되는 몇 가지 클래스 메서드와 클래스 속성을 정의합니다.
•date.max, date.min: 최대값 날짜 객체가 나타낼 수 있는 최소 날짜
•date.solution: 날짜 객체는 날짜의 최소 단위를 나타냅니다. 이곳은 천국이다.
•date.today(): 현재 현지 날짜를 나타내는 날짜 객체를 반환합니다.
•date.fromtimestamp(timestamp): 지정된 타임스탬프를 기반으로 날짜 객체를 반환합니다. 서수): 양력의 시간을 날짜 객체로 변환합니다. (양력: 우리나라의 음력과 유사한 달력 표현 방법으로 서구 국가에서 더 많이 사용되므로 여기서는 자세히 다루지 않습니다.)
사용 예:
from datetime import * import time print 'date.max:', date.max print 'date.min:', date.min print 'date.today():', date.today() print 'date.fromtimestamp():', date.fromtimestamp(time.time()) # # ---- 结果 ---- # date.max: 9999-12-31 # date.min: 0001-01-01 # date.today(): 2010-04-06 # date.fromtimestamp(): 2010-04-06
•date.year, date.month, date.day: 연, 월, 일
• date.replace( year, Month, day): 새 날짜 개체를 생성하고 원본 개체의 속성을 매개변수에 지정된 연도, 월, 일로 바꿉니다. (원래 객체는 변경되지 않습니다.)
•date.timetuple(): 날짜에 해당하는 time.struct_time 객체를 반환합니다.
•date.toordinal(): 날짜에 해당하는 그레고리력 날짜를 반환합니다. >• date.weekday(): 평일을 반환하고, 월요일이면 0을 반환하고, 화요일이면 1을 반환합니다.
•data.isoweekday(): 월요일이면 평일을 반환합니다. 1, 2를 반환합니다.
•date.isocalendar(): (연, 월, 일)과 같은 형식으로 튜플을 반환합니다. isoformat(): ' YYYY-MM-DD' 문자열과 같은 형식을 반환합니다.
•date.strftime(fmt): 사용자 정의 형식 문자열. 아래에서 자세히 설명해주세요.
사용 예:
now = date(2010, 04, 06) tomorrow = now.replace(day = 07) print 'now:', now, ', tomorrow:', tomorrow print 'timetuple():', now.timetuple() print 'weekday():', now.weekday() print 'isoweekday():', now.isoweekday() print 'isocalendar():', now.isocalendar() print 'isoformat():', now.isoformat() # # ---- 结果 ---- # now: 2010-04-06 , tomorrow: 2010-04-07 # timetuple(): (2010, 4, 6, 0, 0, 0, 1, 96, -1) # weekday(): 1 # isoweekday(): 2 # isocalendar(): (2010, 14, 2) # isoformat(): 2010-04-06
•date2 = date1 - timedelta # 날짜를 간격으로 구분하여 새 날짜 객체를 반환합니다
•timedelta = date1 - date2 # 두 날짜를 빼고 시간 간격 객체를 반환합니다.
•date1 < date2 # 두 날짜를 비교합니다.
참고: 날짜를 연산할 때 날짜가 나타낼 수 있는 범위를 초과하지 않도록 하세요.
사용 예:
now = date.today() tomorrow = now.replace(day = 7) delta = tomorrow - now print 'now:', now, ' tomorrow:', tomorrow print 'timedelta:', delta print now + delta print tomorrow > now # # ---- 结果 ---- # now: 2010-04-06 tomorrow: 2010-04-07 # timedelta: 1 day, 0:00:00 # 2010-04-07 # True
Time类
time类表示时间,由时、分、秒以及微秒组成。(我不是从火星来的~~)time类的构造函数如下:
class datetime.time(hour[, minute[, second[, microsecond[, tzinfo]]]]) :各参数的意义不作解释,这里留意一下参数tzinfo,它表示时区信息。注意一下各参数的取值范围:hour的范围为[0, 24),minute的范围为[0, 60),second的范围为[0, 60),microsecond的范围为[0, 1000000)。
time类定义的类属性:
•time.min、time.max:time类所能表示的最小、最大时间。其中,time.min = time(0, 0, 0, 0), time.max = time(23, 59, 59, 999999);
•time.resolution:时间的最小单位,这里是1微秒;
time类提供的实例方法和属性:
•time.hour、time.minute、time.second、time.microsecond:时、分、秒、微秒;
•time.tzinfo:时区信息;
•time.replace([hour[, minute[, second[, microsecond[, tzinfo]]]]]):创建一个新的时间对象,用参数指定的时、分、秒、微秒代替原有对象中的属性(原有对象仍保持不变);
•time.isoformat():返回型如"HH:MM:SS"格式的字符串表示;
•time.strftime(fmt):返回自定义格式化字符串。在下面详细介绍;
使用例子:
from datetime import * tm = time(23, 46, 10) print 'tm:', tm print 'hour: %d, minute: %d, second: %d, microsecond: %d' / % (tm.hour, tm.minute, tm.second, tm.microsecond) tm1 = tm.replace(hour = 20) print 'tm1:', tm1 print 'isoformat():', tm.isoformat() # # ---- 结果 ---- # tm: 23:46:10 # hour: 23, minute: 46, second: 10, microsecond: 0 # tm1: 20:46:10 # isoformat(): 23:46:10
像date一样,也可以对两个time对象进行比较,或者相减返回一个时间间隔对象。这里就不提供例子了。
datetime类
datetime是date与time的结合体,包括date与time的所有信息。它的构造函数如下:datetime.datetime(year, month, day[, hour[, minute[, second[, microsecond[, tzinfo]]]]]),各参数的含义与date、time的构造函数中的一样,要注意参数值的范围。
datetime类定义的类属性与方法:
•datetime.min、datetime.max:datetime所能表示的最小值与最大值;
•datetime.resolution:datetime最小单位;
•datetime.today():返回一个表示当前本地时间的datetime对象;
•datetime.now([tz]):返回一个表示当前本地时间的datetime对象,如果提供了参数tz,则获取tz参数所指时区的本地时间;
•datetime.utcnow():返回一个当前utc时间的datetime对象;
•datetime.fromtimestamp(timestamp[, tz]):根据时间戮创建一个datetime对象,参数tz指定时区信息;
•datetime.utcfromtimestamp(timestamp):根据时间戮创建一个datetime对象;
•datetime.combine(date, time):根据date和time,创建一个datetime对象;
•datetime.strptime(date_string, format):将格式字符串转换为datetime对象;
使用例子:
from datetime import * import time print 'datetime.max:', datetime.max print 'datetime.min:', datetime.min print 'datetime.resolution:', datetime.resolution print 'today():', datetime.today() print 'now():', datetime.now() print 'utcnow():', datetime.utcnow() print 'fromtimestamp(tmstmp):', datetime.fromtimestamp(time.time()) print 'utcfromtimestamp(tmstmp):', datetime.utcfromtimestamp(time.time()) # ---- 结果 ---- # datetime.max: 9999-12-31 23:59:59.999999 # datetime.min: 0001-01-01 00:00:00 # datetime.resolution: 0:00:00.000001 # today(): 2010-04-07 09:48:16.234000 # now(): 2010-04-07 09:48:16.234000 # utcnow(): 2010-04-07 01:48:16.234000 # 中国位于+8时间,与本地时间相差8 # fromtimestamp(tmstmp): 2010-04-07 09:48:16.234000 # utcfromtimestamp(tmstmp): 2010-04-07 01:48:16.234000
datetime类提供的实例方法与属性(很多属性或方法在date和time中已经出现过,在此有类似的意义,这里只罗列这些方法名,具体含义不再逐个展开介绍,可以参考上文对date与time类的讲解。):
•datetime.year、month、day、hour、minute、second、microsecond、tzinfo:
•datetime.date():获取date对象;
•datetime.time():获取time对象;
•datetime.replace([year[, month[, day[, hour[, minute[, second[, microsecond[, tzinfo]]]]]]]]):
•datetime.timetuple()
•datetime.utctimetuple()
•datetime.toordinal()
•datetime.weekday()
•datetime.isocalendar()
•datetime.isoformat([sep])
•datetime.ctime():返回一个日期时间的C格式字符串,等效于time.ctime(time.mktime(dt.timetuple()));
•datetime.strftime(format)
像date一样,也可以对两个datetime对象进行比较,或者相减返回一个时间间隔对象,或者日期时间加上一个间隔返回一个新的日期时间对象。这里不提供详细的例子,看客自己动手试一下~~
格式字符串
datetime、date、time都提供了strftime()方法,该方法接收一个格式字符串,输出日期时间的字符串表示。下表是从python手册中拉过来的,我对些进行了简单的翻译(翻译的有点噢口~~)。
格式字符 意义
%a星期的简写。如 星期三为Web
%A星期的全写。如 星期三为Wednesday
%b月份的简写。如4月份为Apr
%B月份的全写。如4月份为April
%c: 日期时间的字符串表示。(如: 04/07/10 10:43:39)
%d: 日在这个月中的天数(是这个月的第几天)
%f: 微秒(范围[0,999999])
%H: 小时(24小时制,[0, 23])
%I: 小时(12小时制,[0, 11])
%j: 日在年中的天数 [001,366](是当年的第几天)
%m: 月份([01,12])
%M: 分钟([00,59])
%p: AM或者PM
%S: 秒(范围为[00,61],为什么不是[00, 59],参考python手册~_~)
%U: 周在当年的周数当年的第几周),星期天作为周的第一天
%w: 今天在这周的天数,范围为[0, 6],6表示星期天
%W: 周在当年的周数(是当年的第几周),星期一作为周的第一天
%x: 日期字符串(如:04/07/10)
%X: 时间字符串(如:10:43:39)
%y: 2个数字表示的年份
%Y: 4个数字表示的年份
%z: 与utc时间的间隔 (如果是本地时间,返回空字符串)
%Z: 时区名称(如果是本地时间,返回空字符串)
%%: %% => %
例子:
dt = datetime.now() print '(%Y-%m-%d %H:%M:%S %f): ', dt.strftime('%Y-%m-%d %H:%M:%S %f') print '(%Y-%m-%d %H:%M:%S %p): ', dt.strftime('%y-%m-%d %I:%M:%S %p') print '%%a: %s ' % dt.strftime('%a') print '%%A: %s ' % dt.strftime('%A') print '%%b: %s ' % dt.strftime('%b') print '%%B: %s ' % dt.strftime('%B') print '日期时间%%c: %s ' % dt.strftime('%c') print '日期%%x:%s ' % dt.strftime('%x') print '时间%%X:%s ' % dt.strftime('%X') print '今天是这周的第%s天 ' % dt.strftime('%w') print '今天是今年的第%s天 ' % dt.strftime('%j') print '今周是今年的第%s周 ' % dt.strftime('%U') # # ---- 结果 ---- # (%Y-%m-%d %H:%M:%S %f): 2010-04-07 10:52:18 937000 # (%Y-%m-%d %H:%M:%S %p): 10-04-07 10:52:18 AM # %a: Wed # %A: Wednesday # %b: Apr # %B: April # 日期时间%c: 04/07/10 10:52:18 # 日期%x:04/07/10 # 时间%X:10:52:18 # 今天是这周的第3天 # 今天是今年的第097天 # 今周是今年的第14周
这些就是datetime模块的基本内容,总算写完了~~oh yeah~~
更多Python模块学习 datetime介绍相关文章请关注PHP中文网!