Python提供了多個內建模組用於操作日期時間,像calendar,time,datetime。time模組我在之前的文章已經有所介紹,它提供的介面與C標準庫time.h基本一致。相比於time模組,datetime模組的介面則更直觀、更容易呼叫。今天就來講講datetime模組。
datetime模組定義了兩個常量:datetime.MINYEAR和datetime.MAXYEAR,分別表示datetime所能表示的最小、最大年份。其中,MINYEAR = 1,MAXYEAR = 9999。(對於偶等玩家,這個範圍已經足夠用矣~~)
datetime模組定義了下面這幾個類:
- datetime.date:表示日期的類。常用的屬性有year, month, day;
- datetime.time:表示時間的類。常用的屬性有hour, minute, second, microsecond;
- datetime.datetime:表示日期時間。
- datetime.timedelta:表示時間間隔,即兩個時間點之間的長度。
- datetime.tzinfo:與時區有關的相關資訊。(這裡不詳細充分討論該類,感興趣的童鞋可以參考python手冊)
注:上面這些型別的物件都是不可變(immutable)的。
下面詳細介紹這些類的使用方式。
date類
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.max、date.min:date物件所能表示的最大、最小日期;
- date.resolution:date物件表示日期的最小單位。這裡是天。
- date.today():返回一個表示當前本地日期的date物件;
- date.fromtimestamp(timestamp):根據給定的時間戮,返回一個date物件;
- datetime.fromordinal(ordinal):將Gregorian日曆時間轉換為date物件;(Gregorian Calendar:一種日曆表示方法,類似於我國的農曆,西方國家使用比較多,此處不詳細展開討論。)
使用例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
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提供的例項方法和屬性:
- date.year、date.month、date.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):自定義格式化字串。在下面詳細講解。
使用例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
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 |
date還對某些操作進行了過載,它允許我們對日期進行如下一些操作:
- date2 = date1 + timedelta # 日期加上一個間隔,返回一個新的日期物件(timedelta將在下面介紹,表示時間間隔)
- date2 = date1 – timedelta # 日期隔去間隔,返回一個新的日期物件
- timedelta = date1 – date2 # 兩個日期相減,返回一個時間間隔物件
- date1 < date2 # 兩個日期進行比較
注:對日期進行操作時,要防止日期超出它所能表示的範圍。
使用例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
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):返回自定義格式化字串。在下面詳細介紹;
使用例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
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物件;
使用例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
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: 時區名稱(如果是本地時間,返回空字串)
%%: %% => %
例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
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~~