跳到主要內容

Python筆記(14)- 時間模組使用(time與datetime)

我們常常在資料分析或設計特殊功能常常會使用到時間資料的剖析,這邊我們介紹兩個日期時間的相關模組timedatetime

14.1 time模組

我們在使用time模組中的函數必須匯入此模組,即import time

time模組可以有兩種的時間格是,一種稱為時間戳,以秒數表示(19701 100:00:00開始算起),一種則是明確表示年月日時分秒的格式,程式語法如下:


特別注意的是,ctime()中如果不放任何參數,則會回傳當前時間與日期格式,若要放入參數t,則t必須是時間戳,回傳結果則是t對應的時間與日期格式。

如果想要分別取得當前時間的年月日時分秒等訊息,則可使用localtime()函數,如果不放任何參數,則會回傳當前時間的時間元組,若要放入參數t,則t必須是時間戳,回傳結果則是t對應的時間元組。時間元組格式如下:

特別要說明的是tm_wday代表一週中的第幾天,tm_yday則代表一年中的第幾天,tm_isdst則代表時間使否有使用夏令時間,1代表有使用,0代表沒有使用,-1則代表不確定。

我們可以利用時間元組的屬性分別得到年月日時分秒等資訊,範例說明如下:


14.2 使用time模組中的strftime()函數自訂時間格式

要自訂時間格式,就必須先定義時間格式,資料類型為字串,以下我們整理幾個常用到字串所代表的時間意義:

strftime()函數需要兩個參數,時間格式與時間元組,結構如下:strftime(時間格式, 時間元組),以下我們舉幾個範例如下:


14.3 使用time模組中的strptime()函數將時間字串轉換成時間元組

strptime()可以將任意時間字串轉換成時間元組,一樣需要兩個參數,一個是時間字串,另一個是時間字串對應的時間格式,結構如下:strftime(時間字串, 時間格式),以下我們舉幾個範例如下:

14.4 牛刀小試-利用time模組進行時間早晚比對與計算時間差

我們的範例中給訂兩個時間字串,我們利用時間戳的大小關係來比較時間早晚,所以必須將時間字串先轉換成時間戳,這時候會使用到一個函數叫做mktime(t),此函數可以回傳時間戳,但參數t必須為時間元組,所以我們必須先將時間字串轉成時間元組,再透過mktime()轉成時間戳。我們提供範例程式碼如下:

我們可以進一步利用相差的時間戳計算兩個時間相差的天數、時數、分數、秒數,我們提供範例程式碼如下:

14.5 利用time模組中的sleep()函數讓系統停止

我們有時候會需要在程式執行過程途中停止數秒在繼續執行,time模組提供了一個sleep(s)函數可以達到這個功能,其中參數s代表要停止的秒數,我們說明範例如下:


14.6 datetime模組

我們亦可以使用datetime模組分別操作時間與日期的相關資訊。我們在使用datetime模組中的函數必須匯入此模組,即import datetime

若要回傳當前時間與日期或者自訂時間日期,程式寫法如下:

使用dt.datetime()自訂時間日期,參數依序為年、月、日、時、分、秒,即dt.datetime(,,,,,)我們可以使用datetime.datetime的屬性分別得到年月日時分秒等資訊,範例說明如下:

14.7 直接利用datetime.datetime的變數進行時間早晚比較與時間差計算

我們可以直接對datetime.datetime的變數進行減法或比大小來判斷時間早晚比較與時間差。範例說明如下:

這邊特別說明一下,day_2-day_1回傳的是   4 days, 10:18:00,它是datetime.timedelta格式,它提供了days屬性可以直接回傳相差的天數,但比較可惜的是沒有hourminsec等屬性可以回傳,所以想要知道分別知道時數、分數、秒數,可以先將day_2-day_1轉換成字串,透過擷取子字串的方式得到。

留言

這個網誌中的熱門文章

RPA-Uipath筆記(1) - 如何從網路上下載資料並存至指定路徑

最近在做 RPA 相關專案時遇到了這個問題: 如何從網路上下載資料並存至指定路徑? 針對這個問題我們採取的解決方案是 先讓檔案下載到電腦的預設路徑,再將檔案移動到我們指定的資料夾 。 以下我們用下載政府公開資料平台的資料 ("https://data.gov.tw/dataset/116285") 為例, Uipath 的流程建立如下: 使用到了 Wait for Download 、 Move File 、 Delete File 三個 Activity , Wait for Download 中 Monitored folder 必須放瀏覽器中設定的下載檔案的預設路徑且關閉詢問儲存位置。 Downloaded file 則是設定一個變數名稱 downloadfile( 可自訂 ) ,此變數的資料型態是 FileInfo 。中間則放入下載的流程步驟,從下載開始到結束都會在此 Activity 中執行完畢,執行完後所下載的檔案的相關資訊都會被存放在變數 downloadfile 中。 接下來是將檔案從預設下載路徑中移至指定路徑,這裡就需要下載預設路徑與指定路徑,這兩個我們在流程一開始就建了了兩個變數 dnlo_path 、 asng_path ,寫法如下: dnlo_path = "C:\Users\" +system.Environment.UserName+ "\Downloads" system.Environment.UserName à VB 語法,代表目前電腦的使用者名稱。 asng_path = "D:\Bolg 資料 \Uipath\Uipath(1)" Move File Activity 中 From 要放入目前檔案的位置; To 則要放入檔案存放的指定的位置,但因為是要做檔案的移動,所以以上兩個路徑後面都要再加上檔案名稱,這時可以使用 downloadfile 這個變數的屬性值叫出檔案名稱( downloadfile.Name ),當檔案名稱是隨機變動的時候,非常好用。另外,特別值得注意的是, To 的部分在加上檔案名稱時,可以不用用原始檔案的名稱,這時可以同時達到修改檔名的效果。 Overwrite 的部分打勾代表再重複執行一次的時...

RPA-Uipath(2) - 字串分割(String.Split())與合併(String.join())

在資料清理中,我們常常需要對字串進行分割或合併,今天來簡單介紹 Uipath 中字串如何進行分割與合併。 1.      字串分隔 ( 單一分割符號 ) 我們首先建了一個字串變數 Str1= "Jimmy,Johnson,Shawn,Alan,Nick" ,我們現在想把這些人名一個一個切割出來,很明顯只要將 ”,” 作為分個符號就可以了。這邊我們建立一個陣列變數 Str1_Array=Str1.split(","c) ,這個陣列變數就會儲存分割出來的結果。我們接下來用 For each 與 Write Line 將陣列的每一項內容印出來,就可以知道我們分割的結果有沒有成功。 2.      字串分隔 ( 多個分割符號 ) 我們首先建了一個字串變數 Str2= "Jimmy,Johnson.Shawn Alan,Nick" ,我們現在想把這些人名一個一個切割出來,很明顯要將 ”,” 、 ”.” 、 ” “ 都作為分個符號才能完整分割。這邊我們建立一個陣列變數 Str2_Array= Str2.Split(",|.| ".ToArray()) or Str2.Split({","c,"."c," "c}) ,這個陣列變數就會儲存分割出來的結果。我們接下來用 For each 與 Write Line 將陣列的每一項內容印出來,就可以知道我們分割的結果有沒有成功。 3       字串的合併 (Array 字串元素合併 ) 我們首先建了一個字串變數 Str3_Array= {"John","Jimmy","Shawn","Alan"} ,我們現在想把這些人名中間用 ”|” 符號隔開並且變成一個字串,這裡我們是用 String.Join( 連接符號 , 陣列 ) 這個函數達到這個目的。我們建立一個變數 Str3_Join ,使 Str3_Join=String.Join("|", Str3_Array) ,此時 Str3_Join 的結果就會是 John|Jimmy|Shawn|Alan 。我們接下來用 Write...

RPA-Uipath(5)-如何讀取Mail與取得Mail的資訊

本篇主要介紹 Uipath 取得 mail 相關資訊與附件的方法,因為 mail 的種類眾多,本範例以 Gmail 為例。首先在使用 Uipath 取得 Gmail 相關資訊前須對 Google 帳戶的安全性進行兩階段驗證設定,設定方式如下: Step1. 點選 ” 管理你的 Google 帳戶 ” Step2.  點選 ” 安全性 ” à ” 兩階段驗證 ” à 點選 ” 開始使用 ” Step3.  依 Google 所提示步驟,您最後會取得一組密碼,請務必將此密碼記下。 接下來要開始使用 Uipath 擷取 mail 相關資訊,一開始我們先使用 Get Password 儲存 mail 登入的密碼,此時密碼不是使用您真正的密碼而是使用剛剛兩階段驗證後取得的密碼,並儲存於變數 password 。 接下來使用 Get IMAP Mail Messages 來取得 mail 的相關資訊,在使用 Get IMAP Mail Messages 時必須在其屬性設定區塊進行一些參數設定。 Port 欄位填入 993 , Server 欄位填入 "imap.gmail.com" , Email 欄位填入您的 Email , Password 欄位填入 變數 password , Message 欄位我們用 MailMessage 變數填入 Mail 的相關資訊都會存在 MailMessage 變數中,我們可以用 For Each 迴圈逐一取得 mail 的相關資訊。 For Each 的屬性區塊部分也需要進行一些參數設定, List of item 欄位需填入 MailMessage 變數, TypeArgument 則須設定為 System.Net.Mail.MailMessage 。 設定完成後,我們先用 Write Line 將信件的主旨印出做為測試( 這邊我們只印出前 5 封信件的主旨,可在 Get IMAP Mail Messages 的屬性區塊中 Top 欄位中設定 ),如果要印出信件主旨,需要用 item.Subject 屬性,如要印出其他資訊,我們將常用的幾個列在以下表格: 最後,有些信件會附帶一些附件,我們如何將這些物件儲存下來呢 ? 這邊只需要用到 Save Attachments 即可。我們將其放在迴圈內以下載每個有附件的 mail...