日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

Python 日期和時間

 豐千郎 2021-12-10

Python 程序能用很多方式處理日期和時間,轉(zhuǎn)換日期格式是一個常見的功能。

Python 提供了一個 time 和 calendar 模塊可以用于格式化日期和時間。

時間間隔是以秒為單位的浮點小數(shù)。

每個時間戳都以自從1970年1月1日午夜(歷元)經(jīng)過了多長時間來表示。

Python 的 time 模塊下有很多函數(shù)可以轉(zhuǎn)換常見日期格式。如函數(shù)time.time()用于獲取當前時間戳, 如下實例:

#!/usr/bin/python# -*- coding: UTF-8 -*-import time;  # 引入time模塊ticks = time.time()print "Number of ticks since 12:00am, January 1, 1970:", ticks

上述代碼執(zhí)行結(jié)果如下:

Number of ticks since 12:00am, January 1, 1970: 1626082364.68

什么是時間元組?

很多Python函數(shù)用一個元組裝起來的9組數(shù)字處理時間:

序號字段
04位數(shù)年2008
11 到 12
21到31
3小時0到23
4分鐘0到59
50到61 (60或61 是閏秒)
6一周的第幾日0到6 (0是周一)
7一年的第幾日1到366 (儒略歷)
8夏令時-1, 0, 1, -1是決定是否為夏令時的旗幟

#!/usr/bin/python3import timeprint (time.localtime());

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

time.struct_time(tm_year=2021, tm_mon=7, tm_mday=16, tm_hour=8, tm_min=15, tm_sec=25, tm_wday=4, tm_yday=197, tm_isdst=0)

上述也就是struct_time元組。這種結(jié)構(gòu)具有如下屬性:

序號屬性
0tm_year2008
1tm_mon1 到 12
2tm_mday1 到 31
3tm_hour0 到 23
4tm_min0 到 59
5tm_sec0 到 61 (60或61 是閏秒)
6tm_wday0到6 (0是周一)
7tm_yday1 到 366(儒略歷)
8tm_isdst-1, 0, 1, -1是決定是否為夏令時的旗幟


獲取格式化的時間

你可以根據(jù)需求選取各種格式,但是最簡單的獲取可讀的時間模式的函數(shù)是asctime():

#!/usr/bin/python
 import time
 
localtime = time.asctime( time.localtime(time.time()) )print ("本地時間為 :", localtime)
運行示例

以上實例輸出結(jié)果:

本地時間為 : Fri Jul 16 08:17:23 2021

格式化日期

我們可以使用 time 模塊的 strftime 方法來格式化日期,:

time.strftime(format[, t])

#!/usr/bin/python3
 import time 
# 格式化成2016-03-20 11:45:39形式print (time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())) 
# 格式化成Sat Mar 28 22:24:24 2016形式print (time.strftime("%a %b %d %H:%M:%S %Y", time.localtime()))  
# 將格式字符串轉(zhuǎn)換為時間戳a = "Sat Mar 28 22:24:24 2016"print (time.mktime(time.strptime(a,"%a %b %d %H:%M:%S %Y")))

以上實例輸出結(jié)果:

2016-04-07 10:25:09
Thu Apr 07 10:25:09 20161459175064.0

python中時間日期格式化符號:

  • %y 兩位數(shù)的年份表示(00-99)

  • %Y 四位數(shù)的年份表示(000-9999)

  • %m 月份(01-12)

  • %d 月內(nèi)中的一天(0-31)

  • %H 24小時制小時數(shù)(0-23)

  • %I 12小時制小時數(shù)(01-12)

  • %M 分鐘數(shù)(00-59)

  • %S 秒(00-59)

  • %a 本地簡化星期名稱

  • %A 本地完整星期名稱

  • %b 本地簡化的月份名稱

  • %B 本地完整的月份名稱

  • %c 本地相應(yīng)的日期表示和時間表示

  • %j 年內(nèi)的一天(001-366)

  • %p 本地A.M.或P.M.的等價符

  • %U 一年中的星期數(shù)(00-53)星期天為星期的開始

  • %w 星期(0-6),星期天為星期的開始

  • %W 一年中的星期數(shù)(00-53)星期一為星期的開始

  • %x 本地相應(yīng)的日期表示

  • %X 本地相應(yīng)的時間表示

  • %Z 當前時區(qū)的名稱

  • %% %號本身


獲取某月日歷

Calendar模塊有很廣泛的方法用來處理年歷和月歷,例如打印某月的月歷:

#!/usr/bin/python3
 import calendar
cal = calendar.month(2016, 1)print ("Here is the calendar :")print (cal)

以上實例輸出結(jié)果:

    Here is the calendar :
    January 2016
Mo Tu We Th Fr Sa Su
             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 28 29 30 31

Time 模塊

Time 模塊包含了以下內(nèi)置函數(shù),既有時間處理的,也有轉(zhuǎn)換時間格式的:

函數(shù)描述
time.altzone返回格林威治西部的夏令時地區(qū)的偏移秒數(shù)。如果該地區(qū)在格林威治東部會返回負值(如西歐,包括英國)。對夏令時啟用地區(qū)才能使用。
time.asctime([tupletime])接受時間元組并返回一個可讀的形式為"Tue Dec 11 18:07:14 2008"(2008年12月11日 周二18時07分14秒)的24個字符的字符串。
time.clock( )用以浮點數(shù)計算的秒數(shù)返回當前的CPU時間。用來衡量不同程序的耗時,比time.time()更有用。
time.ctime([secs])作用相當于asctime(localtime(secs)),未給參數(shù)相當于asctime()
time.gmtime([secs])接收時間戳(1970紀元后經(jīng)過的浮點秒數(shù))并返回格林威治天文時間下的時間元組t。注:t.tm_isdst始終為0
time.localtime([secs])接收時間戳(1970紀元后經(jīng)過的浮點秒數(shù))并返回當?shù)貢r間下的時間元組t(t.tm_isdst可取0或1,取決于當?shù)禺敃r是不是夏令時)。
time.mktime(tupletime)接受時間元組并返回時間戳(1970紀元后經(jīng)過的浮點秒數(shù))。
time.sleep(secs)推遲調(diào)用線程的運行,secs指秒數(shù)。
time.strftime(fmt[,tupletime])接收以時間元組,并返回以可讀字符串表示的當?shù)貢r間,格式由fmt決定。
time.strptime(str,fmt='%a %b %d %H:%M:%S %Y')根據(jù)fmt的格式把一個時間字符串解析為時間元組。
time.time()返回當前時間的時間戳(1970紀元后經(jīng)過的浮點秒數(shù))。
time.tzset()根據(jù)環(huán)境變量TZ重新初始化時間相關(guān)設(shè)置。

Time模塊包含了以下2個非常重要的屬性:

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

日歷(Calendar)模塊

日歷模塊提供與日歷相關(guān)的功能,包括打印給定月份或年份的文本日歷的功能。

默認情況下,日歷將星期一作為一周的第一天,將星期日作為最后一天。要更改此設(shè)置,請調(diào)用 calendar.setfirstweekday() 函數(shù)。

這是日歷模塊可用的功能列表

序號函數(shù)描述
1calendar.calendar(year,w=2,l=1,c=6)返回一個多行字符串格式的year年年歷,3個月一行,間隔距離為c。 每日寬度間隔為w字符。每行長度為21* W+18+2* C。l是每星期行數(shù)。
2calendar.firstweekday( )返回當前每周起始日期的設(shè)置。默認情況下,首次載入 calendar 模塊時返回 0,即星期一。
3calendar.isleap(year)是閏年返回 True,否則為 False。
4calendar.leapdays(y1,y2)返回在Y1,Y2兩年之間的閏年總數(shù)。
5calendar.month(year,month,w=2,l=1)返回一個多行字符串格式的year年month月日歷,兩行標題,一周一行。每日寬度間隔為w字符。每行的長度為7* w+6。l是每星期的行數(shù)。
6calendar.monthcalendar(year,month)返回一個整數(shù)的單層嵌套列表。每個子列表裝載代表一個星期的整數(shù)。Year年month月外的日期都設(shè)為0;范圍內(nèi)的日子都由該月第幾日表示,從1開始。
7calendar.monthrange(year,month)返回兩個整數(shù)。第一個是該月的星期幾的日期碼,第二個是該月的日期碼。日從0(星期一)到6(星期日);月從1到12。
8calendar.prcal(year,w=2,l=1,c=6)相當于 print calendar.calendar(year,w=2,l=1,c=6)。
9calendar.prmonth(year,month,w=2,l=1)相當于 print calendar.month(year,month,w=2,l=1) 。
10calendar.setfirstweekday(weekday)設(shè)置每周的起始日期碼。0(星期一)到6(星期日)。
11calendar.timegm(tupletime)和time.gmtime相反:接受一個時間元組形式,返回該時刻的時間戳(1970紀元后經(jīng)過的浮點秒數(shù))。
12calendar.weekday(year,month,day)返回給定日期的日期碼。0(星期一)到6(星期日)。月份為 1(一月) 到 12(12月)。

其他相關(guān)模塊和函數(shù)

在Python中,其他處理日期和時間的模塊還有:

    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多