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單位。如下所示:
# 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
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/3486/viewspace-2822935/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- sqlite資料型別 datetime處理SQLite資料型別
- Sql Server基礎:資料型別詳解SQLServer資料型別
- MyBatis(九):MyBatis型別處理器(TypeHandler)詳解MyBatis型別
- python資料庫查詢返回時間為datetime型別時候的特殊處理Python資料庫型別
- Java基礎-泛型詳解Java泛型
- Numpy基礎
- NumPy 超詳細教程(2):資料型別資料型別
- 建立一個MySQL資料庫中的datetime型別MySql資料庫型別
- MySQL資料庫基礎詳解MySql資料庫
- Python Excel處理庫openpyxl詳解PythonExcel
- mysql bigint型別和datetime型別的轉換MySql型別
- Python影像處理初探:Pillow庫的基礎使用Python
- java處理資料庫date型別資料Java資料庫型別
- TypeScript -- 如何處理第三方庫的型別TypeScript型別
- numpy資料型別資料型別
- NumPy 資料型別資料型別
- [java]基礎型別Java型別
- datetime型別簡介(轉)型別
- 【自然語言處理篇】--以NLTK為基礎講解自然語⾔處理的原理和基礎知識自然語言處理
- 圖解python | 基礎資料型別圖解Python資料型別
- 【資料庫】資料庫儲存元素型別基礎資料庫型別
- Flutter (二) Dart 語言基礎詳解 (異常,類,Mixin, 泛型,庫)FlutterDart泛型
- [C++][基礎]5_標準庫型別C++型別
- MySQL的資料型別和建庫策略詳解MySql資料型別
- python-資料分析-NumPy的應用-1、基礎Python
- TypeScript型別系統和基礎型別TypeScript型別
- 【scipy 基礎】--影像處理
- Pandas 基礎 (17) - to_datetime
- NumPy之:資料型別資料型別
- 批處理中的for詳解
- python中時間處理標準庫DateTime加強版庫:pendulumPython
- 基礎資料型別資料型別
- TypeScript(3)基礎型別TypeScript型別
- typeScript 基礎型別 (三)TypeScript型別
- Java 註解與註解處理器基礎總結與實操步驟分析Java
- java的8種基礎型別Java型別
- Oracle LOB資料型別的處理Oracle資料型別
- Python科學計算庫NumPy基礎操作Python