머리말
Python은 달력, 시간, 날짜/시간 등 날짜와 시간을 조작하기 위한 여러 내장 모듈을 제공합니다. time 모듈이 제공하는 인터페이스는 기본적으로 C 표준 라이브러리 time.h와 일치합니다. time 모듈에 비해 datetime 모듈의 인터페이스는 더 직관적이고 호출하기 쉽습니다.
모듈은 두 개의 상수를 정의합니다:
datetime.MINYEAR
datetime.MAXYEAR
이 두 상수는 각각 날짜/시간이 나타낼 수 있는 최소값을 나타냅니다. 그리고 최대 연도. 그 중 MINYEAR = 1, MAXYEAR = 9999입니다.
datetime 모듈은 다음 클래스를 정의합니다.
datetime.date: 날짜를 나타내는 클래스입니다. 일반적으로 사용되는 속성에는 연도, 월, 일이 포함됩니다.
datetime.time: 시간을 나타내는 클래스입니다. 일반적으로 사용되는 속성에는 시, 분, 초, 마이크로초가 포함됩니다.
datetime.datetime: 날짜 및 시간을 나타냅니다.
datetime.timedelta: 시간 간격, 즉 두 시점 사이의 길이를 나타냅니다.
datetime.tzinfo: 시간대 관련 정보입니다.
참고: 위에 나열된 객체 유형은 모두 변경할 수 없습니다.
date class
date 클래스는 날짜(년, 월, 일로 구성)를 나타내며 프로토타입은 다음과 같습니다.
class datetime.date( 연도, 월, 일)
매개변수 설명:
연도의 범위는 [MINYEAR, MAXYEAR], 즉
의 범위입니다.월은 [1 , 12]입니다. (월은 0이 아닌 1부터 시작합니다.)
일의 최대값은 지정된 연도 및 월 매개변수에 따라 결정됩니다. 예를 들어 윤년의 2월은 29일입니다.
date 클래스는 일반적으로 사용되는 몇 가지 클래스 메서드와 속성을 정의합니다.
date.max, date.min: 날짜 개체 최대 및 최소 날짜를 나타낼 수 있습니다.
date.solution: 날짜 개체는 날짜의 가장 작은 단위를 나타냅니다. 이곳은 천국이다.
date.today(): 현재 현지 날짜를 나타내는 날짜 객체를 반환합니다.
date.fromtimestamp(timestamp): 주어진 타임스탬프를 기반으로 날짜 객체를 반환합니다.
datetime.fromordinal(ordinal): 양력의 시간을 날짜로 변환하는 객체; (양력: 우리나라의 음력과 유사한 달력 표현 방법으로, 서방 국가에서 흔히 사용하므로 여기서는 자세히 다루지 않겠습니다.)
사용 예:
>>> datetime.date.max datetime.date(9999, 12, 31) >>> datetime.date.min datetime.date(1, 1, 1) >>> datetime.date.resolution datetime.timedelta(1) >>> datetime.date.today() datetime.date(2016, 5, 12) >>> datetime.date.fromtimestamp(time.time()) datetime.date(2016, 5, 12)
날짜별로 제공되는 인스턴스 메서드 및 속성:
date.year, date . 월, 날짜.일: 연도, 월, 일
date.replace(연도, 월, 일): 원래 객체를 다음에서 지정한 연도, 월, 일로 바꿉니다. 매개변수 속성. (원본 객체는 변경되지 않습니다.)
date.timetuple(): 날짜에 해당하는 time.struct_time 객체를 반환합니다.
date.toordinal(): 날짜에 해당하는 그레고리력 날짜를 반환합니다. date;
date.weekday(): 월요일이면 0을 반환하고, 화요일이면 1을 반환합니다.
data.isoweekday(): 반환; 평일이면 1을 반환하고, 화요일이면 2를 반환합니다.
date.isocalendar(): (연, 월, 일) 형식으로 튜플을 반환합니다. 🎜>
date.isoformat(): 'YYYY-MM-DD' 형식의 문자열을 반환합니다. date.strftime(fmt): 사용자 정의 형식 문자열.>>> today = datetime.date.today() >>> today.year 2016 >>> today.month 5 >>> today.day 12 >>> tomorrow = today.replace(day=13) >>> tomorrow datetime.date(2016, 5, 13) >>> tomorrow.timetuple() time.struct_time(tm_year=2016, tm_mon=5, tm_mday=13, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=4, tm_yday=134, tm_isdst=-1) >>> tomorrow.toordinal() 736097 >>> tomorrow.weekday() 4 >>> tomorrow.isoweekday() 5 >>> tomorrow.isocalendar() (2016, 19, 5) >>> tomorrow.isoformat() '2016-05-13' >>> tomorrow.strftime("%y-%m-%d") '16-05-13'
>>> now = datetime.date.today() >>> now datetime.date(2016, 5, 12) >>> now += datetime.date.resolution >>> now datetime.date(2016, 5, 13) >>> now -= datetime.date.resolution >>> now datetime.date(2016, 5, 12) >>> now < datetime.date.max True
>>> datetime.time.min datetime.time(0, 0) >>> datetime.time.max datetime.time(23, 59, 59, 999999) >>> datetime.time.resolution datetime.timedelta(0, 0, 1)
>>> tm = datetime.time(18, 18, 18) >>> tm.hour 18 >>> tm.minute 18 >>> tm.second 18 >>> tm.microsecond 0 >>> tm.tzinfo >>> tm.isoformat() '18:18:18' >>> tm.replace(hour=20) datetime.time(20, 18, 18) >>> tm.strftime("%I:%M:%S %p") '06:18:18 PM'
class datetime.datetime(year, month, day, hour=0, minute=0, second=0, microsecond=0, tzinfo=None)
各参数的含义与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对象,data 与 time 类没有提供该方法。
使用示例:
>>> datetime.datetime.min datetime.datetime(1, 1, 1, 0, 0) >>> datetime.datetime.max datetime.datetime(9999, 12, 31, 23, 59, 59, 999999) >>> datetime.datetime.resolution datetime.timedelta(0, 0, 1) >>> print datetime.datetime.resolution 0:00:00.000001 >>> today = datetime.datetime.today() >>> today datetime.datetime(2016, 5, 12, 12, 46, 47, 246240) >>> datetime.datetime.now() datetime.datetime(2016, 5, 12, 12, 47, 9, 850643) >>> datetime.datetime.utcnow() datetime.datetime(2016, 5, 12, 4, 47, 42, 188124) >>> datetime.datetime.fromtimestamp(time.time()) datetime.datetime(2016, 5, 12, 12, 48, 40, 459676) >>> datetime.datetime.combine(datetime.date(1990, 10, 05), datetime.time(18, 18, 18)) datetime.datetime(1990, 10, 5, 18, 18, 18) >>> datetime.datetime.strptime("2010-04-07 01:48:16.234000", "%Y-%m-%d %H:%M:%S .%f") datetime.datetime(2010, 4, 7, 1, 48, 16, 234000)
datetime 的实例方法与属性
datetime类提供的实例方法与属性大部分功能与 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)
datetime 对象同样可以进行比较,或者相减返回一个时间间隔对象,或者日期时间加上一个间隔返回一个新的日期时间对象。
timedelta 类
datetime.timedelta 对象代表两个时间之间的的时间差,两个 date 或 datetime 对象相减时可以返回一个timedelta 对象。其原型如下:
class datetime.timedelta(days=0, seconds=0, microseconds=0, milliseconds=0, minutes=0, hours=0, weeks=0)
所有参数可选,且默认都是0,参数的值可以是整数,浮点数,正数或负数。
内部只存储days,seconds,microseconds,其他参数的值会自动按如下规则抓转换:
1 millisecond(毫秒) 转换成 1000 microseconds(微秒)
1 minute 转换成 60 seconds
1 hour 转换成 3600 seconds
1 week转换成 7 days
三个参数的取值范围分别为:
0 <= microseconds < 1000000
0 <= seconds < 3600*24 (the number of seconds in one day)
-999999999 <= days <= 999999999
timedelta 类定义的类属性:
timedelta.min:时间间隔对象的最小值,即 timedelta(-999999999).
timedelta.max:时间间隔对象的最大值,即 timedelta(days=999999999, hours=23, minutes=59, seconds=59, microseconds=999999).
timedelta.resolution:时间间隔的最小单位,即 timedelta(microseconds=1).
使用示例:
>>> datetime.timedelta.min datetime.timedelta(-999999999) >>> datetime.timedelta.max datetime.timedelta(999999999, 86399, 999999) >>> datetime.timedelta.resolution datetime.timedelta(0, 0, 1) >>> print datetime.timedelta.resolution 0:00:00.000001
timedelta 实例方法
timedelta.total_seconds():计算时间间隔的总秒数
使用示例:
>>> datetime.timedelta.resolution.total_seconds() 1e-06
格式字符串
datetime、date、time 都提供了 strftime() 方法,该方法接收一个格式字符串,输出日期时间的字符串表示。支持的转换格式如下:
%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.datetime.now() >>> dt.strftime('%Y-%m-%d %H:%M:%S %f') '2016-05-12 14:19:22 333943' >>> dt.strftime('%y-%m-%d %I:%M:%S %p') '16-05-12 02:19:22 PM' >>> dt.strftime("%a") 'Thu' >>> dt.strftime("%A") 'Thursday' >>> dt.strftime("%b") 'May' >>> dt.strftime("%B") 'May' >>> dt.strftime("%c") 'Thu May 12 14:19:22 2016' >>> dt.strftime("%x") '05/12/16' >>> dt.strftime("%X") '14:19:22' >>> dt.strftime("%w") '4' >>> dt.strftime("%j") '133' >>> dt.strftime("%u") '4' >>> dt.strftime("%U") '19'
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
更多Python中datetime模块参考手册相关文章请关注PHP中文网!