pandas ile tarih ve saat kullanımı

Python ile Zaman Serisi Verilerini Manipüle Etme

Stefan Jansen

Founder & Lead Data Scientist at Applied Artificial Intelligence

Tarih ve zaman serisi işlevleri

  • Temel: tarih ve saat bilgisi için veri tipleri
    • Zaman noktaları ve dönemler için nesneler
    • Öznitelikler ve metotlar zaman ayrıntılarını yansıtır
  • Tarih ve dönem dizileri:
    • Series veya DataFrame sütunları
    • Index: nesneyi Zaman Serisine dönüştürür
  • Birçok Series/DataFrame metodu zaman serisi işlevi için indexten zaman bilgisini kullanır
Python ile Zaman Serisi Verilerini Manipüle Etme

Temel yapı taşı: pd.Timestamp

import pandas as pd  # assumed imported going forward
from datetime import datetime  # To manually create dates

time_stamp = pd.Timestamp(datetime(2017, 1, 1))
pd.Timestamp('2017-01-01') == time_stamp
True # Tarihleri string olarak anlar
time_stamp # type: pandas.tslib.Timestamp
Timestamp('2017-01-01 00:00:00')
Python ile Zaman Serisi Verilerini Manipüle Etme

Temel yapı taşı: pd.Timestamp

  • Timestamp nesnesi zaman bilgisi için birçok özniteliğe sahiptir
time_stamp.year
2017
time_stamp.day_name()
'Sunday'
Python ile Zaman Serisi Verilerini Manipüle Etme

Diğer yapı taşları: pd.Period ve freq

period = pd.Period('2017-01')

period # default: month-end
Period('2017-01', 'M')
period.asfreq('D') # convert to daily
Period('2017-01-31', 'D')
period.to_timestamp().to_period('M')
Period('2017-01', 'M')

 

  • Period nesnesinin frekans bilgisini tutan freq özniteliği vardır

 

  • pd.Period()pd.Timestamp() ve geri dönüşüm
Python ile Zaman Serisi Verilerini Manipüle Etme

Diğer yapı taşları: pd.Period ve freq

period + 2
Period('2017-03', 'M')
pd.Timestamp('2017-01-31', 'M') + 1
Timestamp('2017-02-28 00:00:00', freq='M')
  • Frekans bilgisi temel tarih aritmetiğini sağlar
Python ile Zaman Serisi Verilerini Manipüle Etme

Tarih ve saat dizileri

  • pd.date_range: start, end, periods, freq
index = pd.date_range(start='2017-1-1', periods=12, freq='M')
index
DatetimeIndex(['2017-01-31', '2017-02-28', '2017-03-31', ...,
               '2017-09-30', '2017-10-31', '2017-11-30', '2017-12-31'],
              dtype='datetime64[ns]', freq='M')
  • pd.DateTimeIndex: frekans bilgisine sahip Timestamp nesneleri dizisi
Python ile Zaman Serisi Verilerini Manipüle Etme

Tarih ve saat dizileri

index[0]
Timestamp('2017-01-31 00:00:00', freq='M')
index.to_period()
PeriodIndex(['2017-01', '2017-02', '2017-03', '2017-04', ..., 
             '2017-11', '2017-12'], dtype='period[M]', freq='M')
Python ile Zaman Serisi Verilerini Manipüle Etme

Zaman serisi oluşturma: pd.DateTimeIndex

pd.DataFrame({'data': index}).info()
RangeIndex: 12 entries, 0 to 11
Data columns (total 1 columns):
data    12 non-null datetime64[ns]
dtypes: datetime64[ns](1)
Python ile Zaman Serisi Verilerini Manipüle Etme

Zaman serisi oluşturma: pd.DateTimeIndex

  • np.random.random:
    • Rastgele sayılar: [0,1]
    • 12 satır, 2 sütun
data = np.random.random((size=12,2))

pd.DataFrame(data=data, index=index).info()
DatetimeIndex: 12 entries, 2017-01-31 to 2017-12-31
Freq: M
Data columns (total 2 columns):
0    12 non-null float64
1    12 non-null float64
dtypes: float64(2)
Python ile Zaman Serisi Verilerini Manipüle Etme

Frekans kısaltmaları ve zaman bilgisi

ch1_1_v2 -How to use Dates & Times with pandas.036.png

Python ile Zaman Serisi Verilerini Manipüle Etme

Haydi pratik yapalım!

Python ile Zaman Serisi Verilerini Manipüle Etme

Preparing Video For Download...