>백엔드 개발 >파이썬 튜토리얼 >Python의 datetime 모듈 소개(예제 포함)

Python의 datetime 모듈 소개(예제 포함)

不言
不言앞으로
2019-01-28 11:31:213038검색

이 글은 Python의 datetime 모듈을 소개합니다(예제 포함). 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.

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(년, 월, 일)

매개변수 설명: date 类表示一个日期(由年、月、日组成),其原型如下:

class datetime.date(year, month, day)

参数说明:

  • year 的范围是 [MINYEAR, MAXYEAR],即 [1, 9999];

  • month 的范围是[1, 12]。(月份是从1开始的,不是从0开始);

  • day 的最大值根据给定的year, month参数来决定。例如闰年2月份有29天;

date 类定义了一些常用的类方法与类属性:

  • date.maxdate.min:date对象所能表示的最大、最小日期;

  • date.resolution:date对象表示日期的最小单位。这里是天。

  • date.today():返回一个表示当前本地日期的 date 对象;

  • date.fromtimestamp(timestamp):根据给定的时间戮,返回一个 date 对象;

  • datetime.fromordinal(ordinal):将Gregorian日历时间转换为date对象;(Gregorian Calendar:一种日历表示方法,类似于我国的农历,西方国家使用比较多,此处不详细展开讨论。)

使用示例:

>>> 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提供的实例方法和属性:

  • date.yeardate.monthdate.day:年、月、日;

  • date.replace(year, month, day):生成一个新的日期对象,用参数指定的年,月,日代替原有对象中的属性。(原有对象仍保持不变)

  • date.timetuple():返回日期对应的time.struct_time对象;

  • date.toordinal():返回日期对应的Gregorian Calendar日期;

  • date.weekday():返回weekday,如果是星期一,返回0;如果是星期2,返回1,以此类推;

  • data.isoweekday():返回weekday,如果是星期一,返回1;如果是星期2,返回2,以此类推;

  • date.isocalendar():返回格式如(year,month,day)的元组;

  • 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'

date 重载了简单的运算符:

date 允许对日期进行加减和比较:

  • date2 = date1 + timedelta

日期加上一个间隔,返回一个新的日期对象

  • date2 = date1 - timedelta

日期隔去间隔,返回一个新的日期对象

  • timedelta = date1 - date2

两个日期相减,返回一个时间间隔对象

  • date1 < date2

两个日期进行比较。

使用示例:

>>> 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

Time类

time

연도 범위는 [MINYEAR, MAXYEAR], 즉 [1, 9999]입니다.

#🎜🎜##🎜🎜#month의 범위는 [1, 12]입니다. (월은 0이 아닌 1부터 시작합니다.) #🎜🎜##🎜🎜##🎜🎜##🎜🎜#day의 최대값은 지정된 연도 및 월 매개변수에 따라 결정됩니다. 예를 들어, 윤년의 2월은 29일입니다. #🎜🎜##🎜🎜##🎜🎜#

날짜 클래스는 일반적으로 사용되는 몇 가지 클래스 메서드와 속성을 정의합니다.

#🎜🎜##🎜🎜 ##🎜 🎜##🎜🎜#date.max#🎜🎜#, #🎜🎜#date.min#🎜🎜#: 날짜 객체가 나타낼 수 있는 최대 및 최소 날짜 #🎜🎜##🎜🎜## 🎜🎜## 🎜🎜##🎜🎜#date.solution#🎜🎜#: 날짜 개체는 날짜의 가장 작은 단위를 나타냅니다. 이곳은 천국이다. #🎜🎜##🎜🎜##🎜🎜##🎜🎜##🎜🎜#date.today()#🎜🎜#: 현재 현지 날짜를 나타내는 날짜 객체를 반환합니다. #🎜🎜##🎜🎜##🎜 🎜##🎜🎜##🎜🎜#date.fromtimestamp(timestamp)#🎜🎜#: 주어진 타임스탬프를 기반으로 날짜 객체를 반환합니다. #🎜🎜##🎜🎜##🎜🎜##🎜🎜## 🎜 🎜#datetime.fromordinal(ordinal)#🎜🎜#: 그레고리력 시간을 날짜 객체로 변환합니다. (그레고리력: 우리나라의 음력과 유사한 달력 표현 방법으로 서양 국가에서 더 많이 사용되며 여기서는 자세히 설명하지 않습니다.)# 🎜🎜##🎜🎜##🎜🎜##🎜🎜#사용 예: #🎜🎜#
>>> datetime.time.min
datetime.time(0, 0)
>>> datetime.time.max
datetime.time(23, 59, 59, 999999)
>>> datetime.time.resolution
datetime.timedelta(0, 0, 1)<h4>날짜별로 제공되는 인스턴스 메서드 및 속성:</h4>#🎜🎜##🎜🎜# #🎜🎜# #🎜🎜#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()#🎜🎜#: (연도, 월, 일) 형식의 튜플을 반환합니다. #🎜🎜##🎜🎜##🎜🎜 ##🎜 🎜##🎜🎜#date.isoformat()#🎜🎜#: 'YYYY-MM-DD' 형식의 문자열을 반환합니다. #🎜🎜##🎜🎜##🎜🎜##🎜🎜# #🎜🎜# date.strftime(fmt)#🎜🎜#: 사용자 정의 형식 문자열. #🎜🎜##🎜🎜##🎜🎜##🎜🎜#사용 예: #🎜🎜#<pre class="brush:php;toolbar:false">>>> 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'

date는 간단한 연산자를 오버로드합니다.

#🎜🎜#date는 날짜 추가를 허용합니다 빼기 및 비교: # 🎜🎜##🎜🎜##🎜🎜##🎜🎜##🎜🎜#date2 = date1 + timedelta#🎜🎜#: #🎜🎜##🎜🎜##🎜🎜##🎜🎜# 날짜, 새 날짜 객체 반환 #🎜🎜##🎜🎜##🎜🎜##🎜🎜##🎜🎜#date2 = date1 - timedelta#🎜🎜#: #🎜🎜##🎜🎜# #🎜🎜## 🎜🎜#날짜를 간격으로 구분하여 새 날짜 객체를 반환합니다#🎜🎜##🎜🎜##🎜🎜##🎜🎜##🎜🎜#timedelta = date1 - date2#🎜🎜#:# 🎜🎜## 🎜🎜##🎜🎜##🎜🎜#두 날짜를 빼고 시간 간격 객체 반환#🎜🎜##🎜🎜##🎜🎜##🎜🎜##🎜🎜#date1 < date2 #🎜🎜#: # 🎜🎜##🎜🎜##🎜🎜##🎜🎜#두 날짜를 비교하세요. #🎜🎜##🎜🎜#사용 예: #🎜🎜#
>>> 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)#🎜🎜#Time class#🎜🎜##🎜🎜#<code>time</code> 클래스는 시간을 나타냅니다(시간, 분, 초 및 마이크로초), 그 프로토타입은 다음과 같습니다: #🎜🎜##🎜🎜#class datetime.time(hour=0, Minute=0, second=0, microsecond=0, tzinfo=None)#🎜🎜##🎜🎜 #매개변수 설명:#🎜🎜#<ul class=" list-paddingleft-2">
<li><p>hour 的范围为[0, 24),</p></li>
<li><p>minute 的范围为[0, 60),</p></li>
<li><p>second 的范围为[0, 60),</p></li>
<li><p>microsecond 的范围为[0, 1000000),</p></li>
<li><p>tzinfo 表示时区信息。</p></li>
</ul>
<h4>time 类定义的类属性:</h4>
<ul class=" list-paddingleft-2">
<li><p><strong>time.min</strong>、<strong>time.ma</strong>x:time类所能表示的最小、最大时间。其中,time.min = time(0, 0, 0, 0), time.max = time(23, 59, 59, 999999);</p></li>
<li><p><strong>time.resolution</strong>:时间的最小单位,这里是1微秒;</p></li>
</ul>
<p>使用示例:</p>
<pre class="brush:php;toolbar:false">>>> datetime.time.min
datetime.time(0, 0)
>>> datetime.time.max
datetime.time(23, 59, 59, 999999)
>>> datetime.time.resolution
datetime.timedelta(0, 0, 1)

time类提供的实例方法和属性:

  • time.hourtime.minutetime.secondtime.microsecond:时、分、秒、微秒;

  • time.tzinfo:时区信息;

  • time.replace([hour[, minute[, second[, microsecond[, tzinfo]]]]]):创建一个新的时间对象,用参数指定的时、分、秒、微秒代替原有对象中的属性(原有对象仍保持不变);

  • time.isoformat():返回型如"HH:MM:SS"格式的字符串表示;

  • time.strftime(fmt):返回自定义格式化字符串。

使用示例:

>>> 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'

time 类的对象只能进行比较,无法进行加减操作。

datetime 类

datetime 是 date 与 time 的结合体,包括 date 与 time 的所有信息。其原型如下:

class datetime.datetime(year, month, day, hour=0, minute=0, second=0, microsecond=0, tzinfo=None)

各参数的含义与date、time的构造函数中的一样,要注意参数值的范围。

datetime类定义的类属性与方法:

  • datetime.mindatetime.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.yearmonthdayhourminutesecondmicrosecondtzinfo

  • 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</p>
<h4>timedelta 实例方法</h4>
<ul class=" list-paddingleft-2"><li><p><strong>timedelta.total_seconds()</strong>:计算时间间隔的总秒数</p></li></ul>
<p>使用示例:</p>
<pre class="brush:php;toolbar:false">>>> 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 segmentfault.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제