91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python中Numpy庫datetime類型的處理是怎樣的

發布時間:2021-10-25 19:14:17 來源:億速云 閱讀:200 作者:柒染 欄目:編程語言

本篇文章給大家分享的是有關Python中Numpy庫datetime類型的處理是怎樣的,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

關于時間的處理,Python中自帶的處理時間的模塊就有time 、datetime、calendar,另外還有擴展的第三方庫,如dateutil等等。通過這些途徑可以隨心所欲地用Python去處理時間。當我們用NumPy庫做數據分析時,如何轉換時間呢?

在NumPy 1.7版本開始,它的核心數組(ndarray)對象支持datetime相關功能,由于’datetime’這個數據類型名稱已經在Python自帶的datetime模塊中使用了, NumPy中時間數據的類型稱為’datetime64’。

單個時間格式字符串轉換為numpy的datetime對象,可使用datetime64實例化一個對象,如下所示:

#時間字符串轉numpy.datetime64
datetime_nd=np.datetime64('2019-01-01')
print(type(datetime_nd))#<class 'numpy.datetime64'>

反過來numpy的datetime對象轉換為時間格式字符串,可使用datetime_as_string()函數,如下所示:

#numpy.datetime64轉時間字符串
datetime_str=np.datetime_as_string(datetime_nd)
print(type(datetime_str))#<class 'numpy.str_'>

從時間格式字符串數組去創建numpy的datetime對象數組(array)時,可以直接使用numpy.array()函數,指定dtype為’datetime64’,這樣的話數組中的元素為’datetime64’類型,如下所示:

datetime_array = np.array(['2019-01-05','2019-01-02','2019-01-03'], dtype='datetime64')
print(datetime_array)#['2019-01-05' '2019-01-02' '2019-01-03']
print(type(datetime_array))#<class 'numpy.ndarray'>
print(type(datetime_array[0]))#<class 'numpy.datetime64'>

也可以通過numpy.arange()函數,給定時間起始范圍去創建numpy的datetime對象數組(array),指定dtype為’datetime64’時默認以日為時間間隔,如下所示:

datetime_array = np.arange('2019-01-05','2019-01-10', dtype='datetime64')
print(datetime_array)#['2019-01-05' '2019-01-06' '2019-01-07' '2019-01-08' '2019-01-09']

設定numpy.arange()函數中的dtype參數,可以調整時間的間隔,比如以年、月、周,甚至小時、分鐘、毫秒程度的間隔生成時間數組,這點和Python的datetime模塊是一樣的,分為了date單位和time單位。如下所示:

Python中Numpy庫datetime類型的處理是怎樣的

# generate year datetime array
datetime_array = np.arange('2018-01-01','2020-01-01', dtype='datetime64[Y]')
print(datetime_array)#['2018' '2019']
# generate month datetime array
datetime_array = np.arange('2019-01-01','2019-10-01', dtype='datetime64[M]')
print(datetime_array)#['2019-01' '2019-02' '2019-03' '2019-04' '2019-05' '2019-06' '2019-07' '2019-08' '2019-09']
# generate week datetime array
datetime_array = np.arange('2019-01-05','2019-02-10', dtype='datetime64[W]')
print(datetime_array)#['2019-01-03' '2019-01-10' '2019-01-17' '2019-01-24' '2019-01-31']
# generate ms datetime array
datetime_array = np.arange('2019-01-05','2019-01-10', dtype='datetime64[ms]')
print(datetime_array)
#['2019-01-05T00:00:00.000' '2019-01-05T00:00:00.001'
# '2019-01-05T00:00:00.002' ... '2019-01-09T23:59:59.997'
# '2019-01-09T23:59:59.998' '2019-01-09T23:59:59.999']

將numpy.datetime64轉化為datetime格式轉換為datetime格式,可使用astype()方法轉換數據類型,如下所示:

#numpy.datetime64轉化為datetime格式
datetime_df=datetime_nd.astype(datetime.datetime)
print(type(datetime_df))#<class 'datetime.date'>

另外,numpy也提供了datetime.timedelta類的功能,支持兩個時間對象的運算,得到一個時間單位形式的數值。因為numpy的核心數組(ndarray)對象沒有物理量系統(physical quantities system),所以創建了timedelta64數據類型來補充datetime64。datetime和timedelta結合提供了更簡單的datetime計算方法。如下所示:

# numpy.datetime64 calculations
datetime_delta = np.datetime64('2009-01-01') - np.datetime64('2008-01-01')
print(datetime_delta)#366 days
print(type(datetime_delta))#<class 'numpy.timedelta64'>
datetime_delta = np.datetime64('2009') + np.timedelta64(20, 'D')
print(datetime_delta)#2009-01-21
datetime_delta = np.datetime64('2011-06-15T00:00') + np.timedelta64(12, 'h')
print(datetime_delta)#2011-06-15T12:00
datetime_delta = np.timedelta64(1,'W') / np.timedelta64(1,'D')
print(datetime_delta)#7.0

以上就是Python中Numpy庫datetime類型的處理是怎樣的,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阿坝| 哈密市| 买车| 逊克县| 达拉特旗| 容城县| 石景山区| 子洲县| 京山县| 海兴县| 商都县| 富民县| 广昌县| 延长县| 漳平市| 罗平县| 康保县| 建昌县| 枣阳市| 定西市| 张掖市| 视频| 临猗县| 老河口市| 冕宁县| 金沙县| 汉源县| 兴业县| 栾川县| 明光市| 广丰县| 锡林浩特市| 马边| 易门县| 公安县| 昌邑市| 乳山市| 兴化市| 手机| 砀山县| 息烽县|