chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Python的時間處理模塊中處理日期與時間的全面總結(jié)

馬哥Linux運維 ? 來源:標點符 ? 作者:錢魏Way ? 2021-10-12 09:24 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

Python的時間處理模塊在日常的使用中用的較多,但是使用的時候基本上都是要查資料,還是有些麻煩的,梳理下,便于以后方便的使用。

時間相關(guān)概念

在1967年的第13屆國際度量衡會議上決定以原子時定義的秒作為時間的國際標準單位:銫133原子基態(tài)的兩個超精細能階間躍遷對應(yīng)輻射的9,192,631,770個周期的持續(xù)時間, 起始歷元定在1958年1月1日0時。

原子鐘是一種時鐘,它以原子共振頻率標準來計算及保持時間的準確。原子鐘是世界上已知最準確的時間測量和頻率標準。

GMT格林威治標準時間(Greenwich Mean Time),是指位于倫敦郊區(qū)的皇家格林威治天文臺的標準時間,因為本初子午線(Prime meridian)被定義為通過那里的經(jīng)線。GMT也叫世界時UT。

UTC協(xié)調(diào)世界時間(Coordinated Universal Time), 又稱世界標準時間,基于國際原子鐘,誤差為每日數(shù)納秒。協(xié)調(diào)世界時的秒長與原子時的秒長一致,在時刻上則要求盡量與世界時接近(規(guī)定二者的差值保持在 0.9秒以內(nèi))。

閏秒不只有閏年,還有閏秒。閏秒是指為保持協(xié)調(diào)世界時接近于世界時時刻,由國際計量局統(tǒng)一規(guī)定在年底或年中(也可能在季末)對協(xié)調(diào)世界時增加或減少1秒的調(diào)整。由于地球自轉(zhuǎn)的不均勻性和長期變慢性(主要由潮汐摩擦引起的),會使世界時(民用時)和原子時之間相差超過到±0.9秒時,就把世界時向前撥1秒(負閏秒,最后一分鐘為59秒)或向后撥1秒(正閏秒,最后一分鐘為61秒);閏秒一般加在公歷年末或公歷六月末。

時區(qū)是地球上的區(qū)域使用同一個時間定義。有關(guān)國際會議決定將地球表面按經(jīng)線從南到北,劃分成24個時區(qū),并且規(guī)定相鄰區(qū)域的時間相差1小時。當人們跨過一個區(qū)域,就將自己的時鐘校正1小時(向西減1小時,向東加1小時),跨過幾個區(qū)域就加或減幾小時。比如我大中國處于東八區(qū),表示為GMT+8。

夏令時(Daylight Saving Time:DST),又稱日光節(jié)約時制、日光節(jié)約時間或夏令時間。這是一種為節(jié)約能源而人為規(guī)定地方時間的制度,在夏天的時候,白天的時間會比較長,所以為了節(jié)約用電,因此在夏天的時候某些地區(qū)會將他們的時間定早一小時,也就是說,原本時區(qū)是8點好了,但是因為夏天太陽比較早出現(xiàn),因此把時間向前挪,在原本8點的時候,訂定為該天的9點(時間提早一小時)~如此一來,我們就可以利用陽光照明,省去了花費電力的時間,因此才會稱之為夏季節(jié)約時間!

Unix時間戳指的是從協(xié)調(diào)世界時(UTC)1970年1月1日0時0分0秒開始到現(xiàn)在的總秒數(shù),不考慮閏秒。

Python time模塊

在 Python 文檔里,time是歸類在Generic Operating System Services中,換句話說, 它提供的功能是更加接近于操作系統(tǒng)層面的。通讀文檔可知,time 模塊是圍繞著 Unix Timestamp 進行的。

該模塊主要包括一個類 struct_time,另外其他幾個函數(shù)及相關(guān)常量。需要注意的是在該模塊中的大多數(shù)函數(shù)是調(diào)用了所在平臺C library的同名函數(shù), 所以要特別注意有些函數(shù)是平臺相關(guān)的,可能會在不同的平臺有不同的效果。
另外一點是,由于是基于Unix Timestamp,所以其所能表述的日期范圍被限定在 1970 – 2038 之間,如果你寫的代碼需要處理在前面所述范圍之外的日期,那可能需要考慮使用datetime模塊更好。

獲取當前時間和轉(zhuǎn)化時間格式

  • time() 返回時間戳格式的時間 (相對于1.1 0000以秒計算的偏移量)
  • ctime() 返回字符串形式的時間,可以傳入時間戳格式時間,用來做轉(zhuǎn)化
  • asctime() 返回字符串形式的時間,可以傳入struct_time形式時間,用來做轉(zhuǎn)化
  • localtime() 返回當前時間的struct_time形式,可傳入時間戳格式時間,用來做轉(zhuǎn)化
  • gmtime() 返回當前時間的struct_time形式,UTC時區(qū)(0時區(qū)) ,可傳入時間戳格式時間,用來做轉(zhuǎn)化
>>>importtime
>>>time.time()
1473386416.954
>>>time.ctime()
'FriSep0910252016'
>>>time.ctime(time.time())
'FriSep0910082016'
>>>time.asctime()
'FriSep0910402016'
>>>time.asctime(time.localtime())
'FriSep0910002016'
>>>time.localtime()
time.struct_time(tm_year=2016,tm_mon=9,tm_mday=9,tm_hour=10,tm_min=1,tm_sec=19,tm_wday=4,tm_yday=253,tm_isdst=0)
>>>time.localtime(time.time())
time.struct_time(tm_year=2016,tm_mon=9,tm_mday=9,tm_hour=10,tm_min=19,tm_sec=11,tm_wday=4,tm_yday=253,tm_isdst=0)
>>>time.gmtime()
time.struct_time(tm_year=2016,tm_mon=9,tm_mday=9,tm_hour=2,tm_min=13,tm_sec=10,tm_wday=4,tm_yday=253,tm_isdst=0)
>>>time.gmtime(time.time())
time.struct_time(tm_year=2016,tm_mon=9,tm_mday=9,tm_hour=2,tm_min=15,tm_sec=35,tm_wday=4,tm_yday=253,tm_isdst=0)

struct_time共有9個元素,其中前面6個為年月日時分秒,后面三個分別代表的含義為:

  • tm_wday 一周的第幾天(周日是0)
  • tm_yday 一年的第幾天
  • tm_isdst 是否是夏令時

時間格式化

time.mktime()

將一個以struct_time格式轉(zhuǎn)換為時間戳

>>>time.mktime(time.localtime())
1473388585.0

time.strftime(format[,t]) 把一個struct_time時間轉(zhuǎn)化為格式化的時間字符串。如果t未指定,將傳入time.localtime()。如果元組中任何一個元素越界,ValueError的錯誤將會被拋出。

  • %c 本地相應(yīng)的日期和時間表示
  • %x 本地相應(yīng)日期
  • %X 本地相應(yīng)時間
  • %y 去掉世紀的年份(00 – 99)
  • %Y 完整的年份
  • %m 月份(01 – 12)
  • %b 本地簡化月份名稱
  • %B 本地完整月份名稱
  • %d 一個月中的第幾天(01 – 31)
  • %j 一年中的第幾天(001 – 366)
  • %U 一年中的星期數(shù)。(00 – 53星期天是一個星期的開始。)第一個星期天之前的所有天數(shù)都放在第0周。
  • %W 和%U基本相同,不同的是%W以星期一為一個星期的開始。
  • %w 一個星期中的第幾天(0 – 6,0是星期天)
  • %a 本地(locale)簡化星期名稱
  • %A 本地完整星期名稱
  • %H 一天中的第幾個小時(24小時制,00 – 23)
  • %I 第幾個小時(12小時制,01 – 12)
  • %p 本地am或者pm的相應(yīng)符,“%p”只有與“%I”配合使用才有效果。
  • %M 分鐘數(shù)(00 – 59)
  • %S 秒(01 – 61),文檔中強調(diào)確實是0 – 61,而不是59,閏年秒占兩秒
  • %Z 時區(qū)的名字(如果不存在為空字符)
  • %% ‘%’字符
>>>time.strftime("%Y-%m-%d%H:%M:%S",time.localtime())
'2016-09-091021'

time.strptime(string[,format])

把一個格式化時間字符串轉(zhuǎn)化為struct_time。實際上它和strftime()是逆操作。

>>>time.strptime(time.ctime())
time.struct_time(tm_year=2016,tm_mon=9,tm_mday=9,tm_hour=11,tm_min=0,tm_sec=4,tm_wday=4,tm_yday=253,tm_isdst=-1)

計時器功能

time.sleep(secs)

線程推遲指定的時間運行。單位為秒。

time.clock()

這個需要注意,在不同的系統(tǒng)上含義不同。在UNIX系統(tǒng)上,它返回的是“進程時間”,它是用秒表示的浮點數(shù)(時間戳)。而在WINDOWS中,第一次調(diào)用,返回的是進程運行的實際時間。而第二次之后的調(diào)用是自第一次調(diào)用以后到現(xiàn)在的運行時間。(實際上是以WIN32上QueryPerformanceCounter()為基礎(chǔ),它比毫秒表示更為精確)

importtime
time.sleep(1)
print("clock1:%s"%time.clock())
time.sleep(1)
print("clock2:%s"%time.clock())
time.sleep(1)
print("clock3:%s"%time.clock())

運行結(jié)果為:

clock1:1.57895443216e-06
clock2:1.00064381867
clock3:2.00158724394

其中第一個clock()輸出的是程序運行時間,第二、三個clock()輸出的都是與第一個clock的時間間隔

time模塊其他內(nèi)置函數(shù)

  • altzone() 返回格林威治西部的夏令時地區(qū)的偏移秒數(shù)。如果該地區(qū)在格林威治東部會返回負值(如西歐,包括英國)。對夏令時啟用地區(qū)才能使用。
  • tzset() 根據(jù)環(huán)境變量TZ重新初始化時間相關(guān)設(shè)置。

time模塊包含的屬性

  • timezone 是當?shù)貢r區(qū)(未啟動夏令時)距離格林威治的偏移秒數(shù)(>0,美洲;<=0大部分歐洲,亞洲,非洲)。
  • tzname 包含一對根據(jù)情況的不同而不同的字符串,分別是帶夏令時的本地時區(qū)名稱和不帶的。
importtime
print(time.timezone)
print(time.tzname)
print(time.tzname[0].decode("GBK"))
print(time.tzname[1].decode("GBK"))

運行結(jié)果

-28800
('xd6xd0xb9xfaxb1xeaxd7xbcxcaxb1xbcxe4','xd6xd0xb9xfaxcfxc4xc1xeexcaxb1')
中國標準時間
中國夏令時

datetime模塊

datetime 比 time 高級了不少,可以理解為 datetime 基于 time 進行了封裝,提供了更多實用的函數(shù)。

datetime模塊定義了下面這幾個類:

  • date:表示日期的類。常用的屬性有year, month, day
  • time:表示時間的類。常用的屬性有hour, minute, second, microsecond
  • datetime:表示日期時間
  • timedelta:表示時間間隔,即兩個時間點之間的長度
  • tzinfo:與時區(qū)有關(guān)的相關(guān)信息

注:上面這些類型的對象都是不可變(immutable)的。

date類

date類定義了一些常用的類方法與類屬性:

  • max、min:date對象所能表示的最大、最小日期
  • resolution:date對象表示日期的最小單位。這里是天
  • today():返回一個表示當前本地日期的date對象
  • fromtimestamp(timestamp):根據(jù)給定的時間戮,返回一個date對象
  • fromordinal(ordinal):將Gregorian日歷時間轉(zhuǎn)換為date對象(特殊歷法用不上)
fromdatetimeimportdate
importtime
print('date.max:',date.max)
print('date.min:',date.min)
print('date.resolution:',date.resolution)
print('date.today():',date.today())
print('date.fromtimestamp():',date.fromtimestamp(time.time()))

執(zhí)行結(jié)果:

date.max:9999-12-31
date.min:0001-01-01
date.resolution:1day,0:00:00
date.today():2016-09-12
date.fromtimestamp():2016-09-12

date提供的實例方法和屬性:

  • .year:返回年
  • .month:返回月
  • .day:返回日
  • .replace(year, month, day):生成一個新的日期對象,用參數(shù)指定的年,月,日代替原有對象中的屬性。(原有對象仍保持不變)
  • .weekday():返回weekday,如果是星期一,返回0;如果是星期2,返回1,以此類推
  • .isoweekday():返回weekday,如果是星期一,返回1;如果是星期2,返回2,以此類推
  • .isocalendar():返回格式如(year, wk num, wk day)
  • .isoformat():返回格式如’YYYY-MM-DD’的字符串
  • .strftime(fmt):自定義格式化字符串。與time模塊中的strftime類似。
  • .toordinal():返回日期對應(yīng)的Gregorian Calendar日期
fromdatetimeimportdate
today=date.today()
print('today:',today)
print('.year:',today.year)
print('.month:',today.month)
print('.replace():',today.replace(year=2017))
print('.weekday():',today.weekday())
print('.isoweekday():',today.isoweekday())
print('.isocalendar():',today.isocalendar())
print('.isoformat():',today.isoformat())
print('.strftime():',today.strftime('%Y-%m-%d'))
print('.toordinal():',today.toordinal())

執(zhí)行結(jié)果:

today:2016-09-12
.year:2016
.month:9
.replace():2017-09-12
.weekday():0
.isoweekday():1
.isocalendar():(2016,37,1)
.isoformat():2016-09-12
.strftime():2016-09-12
.toordinal():736219

date還對某些操作進行了重載,它允許我們對日期進行如下一些操作:

  • date2 = date1 + timedelta # 日期加上一個間隔,返回一個新的日期對象
  • date2 = date1 – timedelta # 日期減去一個間隔,返回一個新的日期對象
  • timedelta = date1 – date2 # 兩個日期相減,返回一個時間間隔對象
  • date1 < date2 # 兩個日期進行比較

time類

time類的構(gòu)造函數(shù)如下:(其中參數(shù)tzinfo,它表示時區(qū)信息。)

class datetime.time(hour[, minute[, second[, microsecond[, tzinfo]]]])

time類定義的類屬性:

  • min、max:time類所能表示的最小、最大時間。其中,time.min = time(0, 0, 0, 0), time.max = time(23, 59, 59, 999999)
  • resolution:時間的最小單位,這里是1微秒

time類提供的實例方法和屬性:

  • .hour、.minute、.second、.microsecond:時、分、秒、微秒
  • .tzinfo:時區(qū)信息
  • .replace([hour[, minute[, second[, microsecond[, tzinfo]]]]]):創(chuàng)建一個新的時間對象,用參數(shù)指定的時、分、秒、微秒代替原有對象中的屬性(原有對象仍保持不變);
  • .isoformat():返回型如”HHSS”格式的字符串表示;
  • .strftime(fmt):返回自定義格式化字符串。

像date一樣,也可以對兩個time對象進行比較,或者相減返回一個時間間隔對象。這里就不提供例子了。

datetime類

datetime是date與time的結(jié)合體,包括date與time的所有信息。它的構(gòu)造函數(shù)如下:datetime.datetime(year, month, day[, hour[, minute[, second[, microsecond[, tzinfo]]]]]),各參數(shù)的含義與date、time的構(gòu)造函數(shù)中的一樣,要注意參數(shù)值的范圍。

datetime類定義的類屬性與方法:

  • min、max:datetime所能表示的最小值與最大值;
  • resolution:datetime最小單位;
  • today():返回一個表示當前本地時間的datetime對象;
  • now([tz]):返回一個表示當前本地時間的datetime對象,如果提供了參數(shù)tz,則獲取tz參數(shù)所指時區(qū)的本地時間;
  • utcnow():返回一個當前utc時間的datetime對象;
  • fromtimestamp(timestamp[, tz]):根據(jù)時間戮創(chuàng)建一個datetime對象,參數(shù)tz指定時區(qū)信息;
  • utcfromtimestamp(timestamp):根據(jù)時間戮創(chuàng)建一個datetime對象;
  • combine(date, time):根據(jù)date和time,創(chuàng)建一個datetime對象;
  • strptime(date_string, format):將格式字符串轉(zhuǎn)換為datetime對象;
fromdatetimeimportdatetime
importtime
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()))

運行結(jié)果:

datetime.max:9999-12-3123:59:59.999999
datetime.min:0001-01-0100:00:00
datetime.resolution:0:00:00.000001
today():2016-09-1219:57:00.761000
now():2016-09-1219:57:00.761000
utcnow():2016-09-1211:57:00.761000
fromtimestamp(tmstmp):2016-09-1219:57:00.761000
utcfromtimestamp(tmstmp):2016-09-1211:57:00.761000

datetime類提供的實例方法與屬性(很多屬性或方法在date和time中已經(jīng)出現(xiàn)過,在此有類似的意義,這里只羅列這些方法名,具體含義不再逐個展開介紹,可以參考上文對date與time類的講解。):

year、month、day、hour、minute、second、microsecond、tzinfo:

  • date():獲取date對象;
  • time():獲取time對象;
  • replace([year[, month[, day[, hour[, minute[, second[, microsecond[, tzinfo]]]]]]]]):
  • timetuple()
  • utctimetuple()
  • toordinal()
  • weekday()
  • isocalendar()
  • isoformat([sep])
  • ctime():返回一個日期時間的C格式字符串,等效于ctime(time.mktime(dt.timetuple()));
  • strftime(format)

像date一樣,也可以對兩個datetime對象進行比較,或者相減返回一個時間間隔對象,或者日期時間加上一個間隔返回一個新的日期時間對象。

timedelta類

通過timedelta函數(shù)返回一個timedelta對象,也就是一個表示時間間隔的對象。函數(shù)參數(shù)情況如下所示:

class datetime.timedelta([days[, seconds[, microseconds[, milliseconds[, minutes[, hours[, weeks]]]]]]])

其沒有必填參數(shù),簡單控制的話第一個整數(shù)就是多少天的間隔的意思:

datetime.timedelta(10)

兩個時間間隔對象可以彼此之間相加或相減,返回的仍是一個時間間隔對象。而更方便的是一個datetime對象如果減去一個時間間隔對象,那么返回的對應(yīng)減去之后的datetime對象,然后兩個datetime對象如果相減返回的是一個時間間隔對象。這很是方便。

tzinfo類

tzinfo是一個抽象類,不能被直接實例化。需要派生子類,提供相應(yīng)的標準方法。datetime模塊并不提供tzinfo的任何子類。最簡單的方式是使用pytz模塊。

pytz模塊

pytz是Python的一個時區(qū)處理模塊(同時也包括夏令時),在理解時區(qū)處理模塊之前,需要先要了解一些時區(qū)的概念。

要知道時區(qū)之間的轉(zhuǎn)換關(guān)系,其實這很簡單:把當?shù)貢r間減去當?shù)貢r區(qū),剩下的就是格林威治時間了。例如北京時間的18:00就是1800,相減以后就是1000,因此就是格林威治時間的10:00。

Python的datetime可以處理2種類型的時間,分別為offset-naive和offset-aware。前者是指沒有包含時區(qū)信息的時間,后者是指包含時區(qū)信息的時間,只有同類型的時間才能進行減法運算和比較。

datetime模塊的函數(shù)在默認情況下都只生成offset-naive類型的datetime對象,例如now()、utcnow()、fromtimestamp()、utcfromtimestamp()和strftime()。其中now()和fromtimestamp()可以接受一個tzinfo對象來生成offset-aware類型的datetime對象,但是標準庫并不提供任何已實現(xiàn)的tzinfo類,只能自己實現(xiàn)。

下面就是實現(xiàn)格林威治時間和北京時間的tzinfo類的例子:

ZERO_TIME_DELTA=timedelta(0)
LOCAL_TIME_DELTA=timedelta(hours=8)#本地時區(qū)偏差
classUTC(tzinfo):
defutcoffset(self,dt):
returnZERO_TIME_DELTA
defdst(self,dt):
returnZERO_TIME_DELTA
classLocalTimezone(tzinfo):
defutcoffset(self,dt):
returnLOCAL_TIME_DELTA
defdst(self,dt):
returnZERO_TIME_DELTA
deftzname(self,dt):
return'+08:00'

一個tzinfo類需要實現(xiàn)utcoffset、dst和tzname這3個方法。其中utcoffset需要返回夏時令的時差調(diào)整;tzname需要返回時區(qū)名,如果你不需要用到的話,也可以不實現(xiàn)。

一旦生成了一個offset-aware類型的datetime對象,我們就能調(diào)用它的astimezone()方法,生成其他時區(qū)的時間(會根據(jù)時差來計算)。而如果拿到的是offset-naive類型的datetime對象,也是可以調(diào)用它的replace()方法來替換tzinfo的,只不過這種替換不會根據(jù)時差來調(diào)整其他時間屬性。因此,如果拿到一個格林威治時間的offset-naive類型的datetime對象,直接調(diào)用replace(tzinfo=UTC())即可轉(zhuǎn)換成offset-aware類型,然后再調(diào)用astimezone()生成其他時區(qū)的datetime對象。

看上去一切都很簡單,但不知道你還是否記得上文所述的夏時令。提起夏時令這個玩意,真是讓我頭疼,因為它沒有規(guī)則可循:有的國家實行夏時令,有的國家不實行,有的國家只在部分地區(qū)實行夏時令,有的地區(qū)只在某些年實行夏時令,每個地區(qū)實行夏時令的起止時間都不一定相同,而且有的地方TMD還不是用幾月幾日來指定夏時令的起止時間的,而是用某月的第幾個星期幾這種形式。

pytz模塊,使用Olson TZ Database解決了跨平臺的時區(qū)計算一致性問題,解決了夏令時帶來的計算問題。由于國家和地區(qū)可以自己選擇時區(qū)以及是否使用夏令時,所以pytz模塊在有需要的情況下得更新自己的時區(qū)以及夏令時相關(guān)的信息。

pytz提供了全部的timezone信息,如:

importpytz
print(len(pytz.all_timezones))
print(len(pytz.common_timezones))

運行結(jié)果:

588
436

如果需要獲取某個國家的時區(qū),可以使用如下方式:

importpytz
print(pytz.country_timezones('cn'))

執(zhí)行結(jié)果:

[u'Asia/Shanghai', u'Asia/Urumqi']

中國一個有兩個時區(qū),一個為上海,一個為烏魯木齊,我們來看下我們有什么區(qū)別:

fromdatetimeimportdatetime
importpytz
print(pytz.country_timezones('cn'))
tz1=pytz.timezone(pytz.country_timezones('cn')[0])
print(tz1)
print(datetime.now(tz1))
tz2=pytz.timezone(pytz.country_timezones('cn')[1])
print(tz2)
print(datetime.now(tz2))

執(zhí)行結(jié)果:

[u'Asia/Shanghai',u'Asia/Urumqi']
Asia/Shanghai
2016-09-1409:55:39.384000+08:00
Asia/Urumqi
2016-09-1407:55:39.385000+06:00

可以看到上海是東八區(qū),而烏魯木齊是東六區(qū)。

時區(qū)轉(zhuǎn)換

操作起來有而比較簡單,本地時區(qū)與UTC的互轉(zhuǎn):

fromdatetimeimportdatetime
importpytz
now=datetime.now()
tz=pytz.timezone('Asia/Shanghai')
print(tz.localize(now))
print(pytz.utc.normalize(tz.localize(now)))

執(zhí)行結(jié)果:

2016-09-1410:25:44.633000+08:00
2016-09-1402:25:44.633000+00:00

使用astimezone()可以進行時區(qū)與時區(qū)之間的轉(zhuǎn)換。

fromdatetimeimportdatetime
importpytz
utc=pytz.utc
beijing_time=pytz.timezone('Asia/Shanghai')
japan_time=pytz.timezone('Asia/Tokyo')
now=datetime.now(beijing_time)
print("BeijingTime:",now)
print("UTC:",now.astimezone(utc))
print("JAPANTIME:",now.astimezone(japan_time))

執(zhí)行結(jié)果:

BeijingTime:2016-09-1410:19:22.671000+08:00
UTC:2016-09-1402:19:22.671000+00:00
JAPANTIME:2016-09-1411:19:22.671000+09:00

另外可以采用 replace來修改時區(qū),時區(qū)多出6分鐘(不要使用)。具體原因為:

民國17年(1928年),國民政府統(tǒng)一中國,原中央觀象臺的業(yè)務(wù)由南京政府中央研究院的天文研究所和氣象研究所分別接收。天文研究所編寫的曆書基本上沿襲中央觀象臺的做法,仍將全國劃分為5個標準時區(qū),只是在有關(guān)交氣、合朔、太陽出沒時刻等處,不再使用北平的地方平時,而改以南京所在的標準時區(qū)的區(qū)時即東經(jīng)120°標準時替代。從北平地方平時改為東經(jīng)120°標準時,兩者相差了352秒。

fromdatetimeimportdatetime
importpytz
now=datetime.now()
print(now)
tz=pytz.timezone('Asia/Shanghai')
print(now.replace(tzinfo=tz))

執(zhí)行結(jié)果:

2016-09-1410:29:20.200000
2016-09-1410:29:20.200000+08:06

夏令時處理

由于用到的場景比較少,不做細化學習。

dateutil模塊

安裝模塊:pip install Python-dateutil

parser.parse()

解析時間到datetime格式,支持大部分時間字符串。沒指定時間默認是0點,沒指定日期默認是今天,沒指定年份默認是今年。

fromdateutilimportparser
print(parser.parse("8thMarch,2004"))
print(parser.parse("8March,2004"))
print(parser.parse("March8th,2004"))
print(parser.parse("March8,2004"))
print(parser.parse("2016-09-14"))
print(parser.parse("20160914"))
print(parser.parse("2016/09/14"))
print(parser.parse("09/14/2016"))
print(parser.parse("09,14"))
print(parser.parse("1200"))
print(parser.parse("Wed,Nov12"))

執(zhí)行結(jié)果:

2004-03-0800:00:00
2004-03-0800:00:00
2004-03-0800:00:00
2004-03-0800:00:00
2016-09-1400:00:00
2016-09-1400:00:00
2016-09-1400:00:00
2016-09-1400:00:00
2016-09-0900:00:00
2016-09-1412:00:00
2016-11-1200:00:00

rrule.rrule()

函數(shù)主要功能:按照規(guī)則生成日期和時間。函數(shù)原型如下。

rrule(self, freq, dtstart=None, interval=1, wkst=None, count=None, until=None, bysetpos=None, bymonth=None, bymonthday=None, byyearday=None, byeaster=None, byweekno=None, byweekday=None, byhour=None, byminute=None, bysecond=None, cache=False)

其中:

  • freq:可以理解為單位??梢允?YEARLY, MONTHLY, WEEKLY, DAILY, HOURLY, MINUTELY, SECONDLY。即年月日周時分秒。
  • dtstart,until:是開始和結(jié)束時間。
  • wkst:周開始時間。
  • interval:間隔。
  • count:指定生成多少個。
  • byxxx:指定匹配的周期。比如byweekday=(MO,TU)則只有周一周二的匹配。byweekday可以指定MO,TU,WE,TH,FR,SA,SU。即周一到周日。

更多參考:http://dateutil.readthedocs.io/en/stable/index.html

Arrow

Arrow 提供了一個友好而且非常易懂的方法,用于創(chuàng)建時間、計算時間、格式化時間,還可以對時間做轉(zhuǎn)化、提取、兼容 python datetime 類型。它包括dateutil模塊,根據(jù)其文檔描述Arrow旨在“幫助你使用更少的代碼來處理日期和時間”。

UTC 時間

使用utcnow()功能創(chuàng)建 UTC 時間。

使用to()方法,我們將 UTC 時間轉(zhuǎn)換為本地時間。

importarrow
utc=arrow.utcnow()
print(utc)
print(utc.to('local'))

當?shù)貢r間

本地時間是特定區(qū)域或時區(qū)中的時間。

importarrow
now=arrow.now()
print(now)
print(now.to('UTC'))

使用now()功能創(chuàng)建本地時間。to()方法用于將本地時間轉(zhuǎn)換為 UTC 時間。

解析時間

get()方法用于解析時間。

importarrow
d1=arrow.get('2012-06-051603','YYYY-MM-DDHHss')
print(d1)
d2=arrow.get(1504384602)
print(d2)

該示例從日期和時間字符串以及時間戳解析時間。

Unix 時間戳

importarrow
utc=arrow.utcnow()
print(utc)
unix_time=utc.timestamp
print(unix_time)
date=arrow.Arrow.fromtimestamp(unix_time)
print(date)

該示例顯示本地時間和 Unix 時間。然后,它將 Unix 時間轉(zhuǎn)換回 date 對象。

使用fromtimestamp()方法,我們將 Unix 時間轉(zhuǎn)換回 Arrow 日期對象。

也可以將日期格式化為 Unix 時間。

importarrow
utc=arrow.utcnow()
print(utc.format('X'))

通過將’X’說明符傳遞給format()方法,我們將當前本地日期打印為 Unix 時間。

格式化日期和時間

日期和時間可以用format()方法格式化。

importarrow
now=arrow.now()
year=now.format('YYYY')
print("Year:{0}".format(year))
date=now.format('YYYY-MM-DD')
print("Date:{0}".format(date))
date_time=now.format('YYYY-MM-DDHHss')
print("Dateandtime:{0}".format(date_time))
date_time_zone=now.format('YYYY-MM-DDHHssZZ')
print("Dateandtimeandzone:{0}".format(date_time_zone))

格式說明:

c18a7206-2ac8-11ec-82a8-dac502259ad0.png

轉(zhuǎn)換為區(qū)域時間

importarrow
utc=arrow.utcnow()
print(utc.to('US/Pacific').format('HHss'))
print(utc.to('Europe/Bratislava').format('HHss'))
print(utc.to('Europe/Moscow').format('HHss'))

工作日

可以使用weekday()或format()方法找到日期的工作日。

importarrow
d1=arrow.get('1948-12-13')
print(d1.weekday())
print(d1.format('dddd'))

移動時間

shift()方法用于移動時間。

importarrow
now=arrow.now()
print(now.shift(hours=5).time())
print(now.shift(days=5).date())
print(now.shift(years=-8).date())

夏令時

importarrow
now=arrow.now()
print(now.format("YYYY-MM-DDHHssZZ"))
print(now.dst())

該示例使用dst()顯示夏令時。

人性化的日期和時間

在社交網(wǎng)站上,我們經(jīng)常可以看到諸如“一個小時前”或“ 5 分鐘前”之類的術(shù)語,這些術(shù)語可以為人們提供有關(guān)帖子創(chuàng)建或修改時間的快速信息。Arrow 包含humanize()方法來創(chuàng)建此類術(shù)語。

importarrow
now=arrow.now()
d1=now.shift(minutes=-15).humanize()
print(d1)
d2=now.shift(hours=5).humanize()
print(d2)

ISO 8601類

國際標準ISO 8601,是國際標準化組織的日期和時間的表示方法,全稱為《數(shù)據(jù)存儲和交換形式·信息交換·日期和時間的表示方法》,在API接口開發(fā)中涉及的比較多。

>>>importdateutil.parser
>>>dateutil.parser.parse('2008-09-03T2035.450686Z')#RFC3339format
datetime.datetime(2008,9,3,20,56,35,450686,tzinfo=tzutc())
>>>dateutil.parser.parse('2008-09-03T2035.450686')#ISO8601extendedformat
datetime.datetime(2008,9,3,20,56,35,450686)
>>>dateutil.parser.parse('20080903T205635.450686')#ISO8601basicformat
datetime.datetime(2008,9,3,20,56,35,450686)
>>>dateutil.parser.parse('20080903')#ISO8601basicformat,dateonly
datetime.datetime(2008,9,3,0,0)

或者使用如下方式解析:

>>>datetime.datetime.strptime("2008-09-03T2035.450686Z","%Y-%m-%dT%H:%M:%S.%fZ")

另外還可以使用iso8601模塊

鏈接:https://www.biaodianfu.com/python-datetime.html

編輯:jq
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • UNIX
    +關(guān)注

    關(guān)注

    0

    文章

    296

    瀏覽量

    42943
  • 計時器
    +關(guān)注

    關(guān)注

    1

    文章

    434

    瀏覽量

    35010
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4413

    瀏覽量

    67194
  • 共振
    +關(guān)注

    關(guān)注

    0

    文章

    28

    瀏覽量

    13057
  • python
    +關(guān)注

    關(guān)注

    57

    文章

    4866

    瀏覽量

    89799

原文標題:Python 處理日期與時間的全面總結(jié)

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    輕松入門時間同步:全面解析常見問題與應(yīng)對策略

    常見問題,并提供實用的解決方案,助您快速掌握這一基礎(chǔ)而重要的技能。 一、什么是時間同步? ? 在 LuatOS 開發(fā), 時間同步 是指通過專用硬件模塊或網(wǎng)絡(luò)協(xié)議,將蜂窩模組的本地時鐘
    的頭像 發(fā)表于 01-17 20:01 ?22次閱讀
    輕松入門<b class='flag-5'>時間</b>同步:<b class='flag-5'>全面</b>解析常見問題與應(yīng)對策略

    激光設(shè)備:激光出光時間不準問題處理

    激光設(shè)備作為現(xiàn)代工業(yè)加工的重要工具,其出光時間的精確性直接影響加工質(zhì)量和生產(chǎn)效率。在實際應(yīng)用,出光時間偏差問題可能由多種因素引起,需要系統(tǒng)性地排查和解決。以下是針對該問題的詳細處理
    的頭像 發(fā)表于 12-26 07:35 ?339次閱讀
    激光設(shè)備:激光出光<b class='flag-5'>時間</b>不準問題<b class='flag-5'>處理</b>

    時間頻率標準源有什么功能

    時間頻率
    西安同步電子科技有限公司
    發(fā)布于 :2025年11月04日 17:58:08

    告別時間漂移:部署高精度時鐘同步產(chǎn)品

    產(chǎn)品工作原理:GPS信號接收模塊接收多顆GPS衛(wèi)星發(fā)送的頻率為1575.42Mhz的UTC信號,經(jīng)處理輸出NMEA0183格式或其它標準的信息。微處理單元(MCU)對上述信息進行后續(xù)處理
    的頭像 發(fā)表于 10-28 16:36 ?479次閱讀
    告別<b class='flag-5'>時間</b>漂移:部署高精度時鐘同步產(chǎn)品

    我要怎么校準或設(shè)置智能顯示模塊時間

    我要怎么校準或設(shè)置智能顯示模塊時間?模塊日期時鐘如何修改設(shè)置時間?
    發(fā)表于 10-25 15:23

    NTP時間同步技術(shù):保證網(wǎng)絡(luò)時間精確無比

    解一下NTP時間同步的基本原理。NTP是通過客戶端-服務(wù)器模式進行工作的。在這個模式,有一個或多個NTP服務(wù)器被配置為時間源,其他的計算機或設(shè)備會向這些服務(wù)器請求
    的頭像 發(fā)表于 10-21 14:45 ?442次閱讀
    NTP<b class='flag-5'>時間</b>同步技術(shù):保證網(wǎng)絡(luò)<b class='flag-5'>時間</b>精確無比

    如何解決NB模塊時間不準問題

    產(chǎn)品不良率非常高,發(fā)現(xiàn)時間偏移巨大,每天有15s之多,無法滿足NB應(yīng)用要求。
    的頭像 發(fā)表于 09-24 10:58 ?1664次閱讀
    如何解決NB<b class='flag-5'>模塊</b><b class='flag-5'>時間</b>不準問題

    用艾德克斯IT6500C/D系列測試電源開機時間和上升時間

    AC-DC、DC-DC電源模塊的完整測試往往包括開機時間、關(guān)機時間、上升時間、下降時間的測試。測試系統(tǒng),如艾德克斯ITS9500電源測試系統(tǒng)
    的頭像 發(fā)表于 09-16 17:19 ?820次閱讀
    用艾德克斯IT6500C/D系列測試電源開機<b class='flag-5'>時間</b>和上升<b class='flag-5'>時間</b>

    亞馬遜:調(diào)用訂單退款API自動化處理售后請求,縮短用戶等待時間

    ? 在電商運營,售后處理效率直接影響用戶體驗和平臺聲譽。亞馬遜作為全球領(lǐng)先的電商平臺,其訂單退款API為賣家提供了強大的自動化工具,幫助高效處理退款請求,顯著縮短用戶等待時間。本文將
    的頭像 發(fā)表于 09-11 15:37 ?415次閱讀
    亞馬遜:調(diào)用訂單退款API自動化<b class='flag-5'>處理</b>售后請求,縮短用戶等待<b class='flag-5'>時間</b>

    是誰偷走了我的時間?RTC時間異常的秘密

    的重要性在嵌入式產(chǎn)品,RTC(實時時鐘)模塊負責維持時間的準確性,確保設(shè)備在各種條件下都能保持時間的正確同步。RTC的準確性直接影響數(shù)據(jù)記錄的可靠性、系統(tǒng)協(xié)調(diào)的
    的頭像 發(fā)表于 09-02 11:35 ?2109次閱讀
    是誰偷走了我的<b class='flag-5'>時間</b>?RTC<b class='flag-5'>時間</b>異常的秘密

    賽思高保持小型時鐘模塊:精確時間的守護者

    ,它就像是我們生活的一位精確的時間守護者。高保持小型時鐘模塊是一種高精度的電子設(shè)備,它的準確性遠超過了傳統(tǒng)的機械時鐘。它采用了先進的微處理器技術(shù),可以實現(xiàn)秒級的
    的頭像 發(fā)表于 07-22 14:37 ?364次閱讀
    賽思高保持小型時鐘<b class='flag-5'>模塊</b>:精確<b class='flag-5'>時間</b>的守護者

    基于RK3576的時間參數(shù)系統(tǒng)操作

    ,文章介紹了時間操作API的使用,包括獲取時間戳、系統(tǒng)延時、獲取和設(shè)置系統(tǒng)日期時間等功能,并提供了API測試案例的路徑。這些內(nèi)容為開發(fā)者提供了全面
    的頭像 發(fā)表于 05-12 14:32 ?884次閱讀
    基于RK3576的<b class='flag-5'>時間</b>參數(shù)系統(tǒng)操作

    時間間隔測量分析儀特點總結(jié)

    時間頻率行業(yè),時間間隔測量是不可缺少的一部分,選擇一款合適的時間間隔測量儀就會顯得尤為重要,今天我們來分析一下時間間隔分析儀的特點。 關(guān)鍵詞:時間
    的頭像 發(fā)表于 05-08 11:29 ?448次閱讀
    <b class='flag-5'>時間</b>間隔測量分析儀特點<b class='flag-5'>總結(jié)</b>

    ADSD3500飛行時間深度成像信號處理器技術(shù)手冊

    ADSD3500是一款飛行時間(ToF)深度成像信號處理器(ISP),適用于ADI公司的ToF產(chǎn)品,例如ADTF3175和ADSD3030。這款深度ISP處理來自ToF成像器的原始相位幀,生成最終
    的頭像 發(fā)表于 05-08 09:43 ?988次閱讀
    ADSD3500飛行<b class='flag-5'>時間</b>深度成像信號<b class='flag-5'>處理</b>器技術(shù)手冊

    Python Connector for InterBase連接解決方案

    該連接器可以讓您將多個更新語句提交到 InterBase 數(shù)據(jù)庫服務(wù)器,以便作為批處理進行處理,從而縮短執(zhí)行時間。 安全通信 該連接器支持 InterBase 的 Over-the-Wire (OTW) 加密功能,可在傳
    的頭像 發(fā)表于 01-22 14:34 ?838次閱讀