Düzensiz veriyi düzenli hale getirme

R ile Finansal Verileri İçe Aktarma ve Yönetme

Joshua Ulrich

Quantitative Analyst & quantmod Co-Author and Maintainer

Düzenli tarih-saat dizileri

  • Zaman gözlemleri eşit aralıklıdır
  • seq() yöntemleriyle düzenli tarih-saat dizileri oluşturun:
    • seq.Date()
    • seq.POSIXt() (POSIXct ve POSIXlt)
from_date <- as.Date("2017-01-01")
to_date <- as.Date("2017-01-03")
date_seq <- seq(from = from_date, to = to_date, by = "day")
R ile Finansal Verileri İçe Aktarma ve Yönetme
  • start() ilk indeks değeri
  • end() son indeks değeri
regular_xts <- xts(seq_along(date_seq), order.by = date_seq)
start(regular_xts)
"2017-01-01"
end(regular_xts)
"2017-01-03"
seq(from = start(regular_xts), to = end(regular_xts), by = "day")
"2017-01-01" "2017-01-02" "2017-01-03"
R ile Finansal Verileri İçe Aktarma ve Yönetme

Sıfır genişlikli xts nesneleri

  • İndeksli, verisiz xts nesnesi
zero_width_xts <- xts(, order.by = date_seq)
zero_width_xts
Data:
numeric(0)
Index:
 Date[1:3], format: "2017-01-01" "2017-01-02" "2017-01-03"
str(zero_width_xts)
Sıfır genişlikli bir 'xts' nesnesi
R ile Finansal Verileri İçe Aktarma ve Yönetme

Düzensiz veriden düzenli veri oluşturma

  • Düzenli dizideki her tarih-saate gözlem ekleyin
  • Sonuçta NA oluşur
R ile Finansal Verileri İçe Aktarma ve Yönetme

Düzensiz xts’i düzenli sıfır genişlikli xts ile birleştirme

irregular
           Price
2017-01-02 20.01
2017-01-04 20.02
2017-01-10 20.05
date_seq <- seq(from = start(irregular),
                to = end(irregular),
                by = "day")
regular_xts <- xts(, date_seq)
R ile Finansal Verileri İçe Aktarma ve Yönetme

Düzensiz xts’i düzenli sıfır genişlikli xts ile birleştirme

merge(irregular, regular_xts)
           Price
2017-01-02 20.01
2017-01-03    NA
2017-01-04 20.02
2017-01-05    NA
2017-01-06    NA
2017-01-07    NA
2017-01-08    NA
2017-01-09    NA
2017-01-10 20.05
R ile Finansal Verileri İçe Aktarma ve Yönetme

Eksik değerleri doldurma

merged_xts <- merge(irregular, regular_xts)

na.locf(merged_xts)
           Price
2017-01-02 20.01
2017-01-03 20.01
2017-01-04 20.02
2017-01-05 20.02
2017-01-06 20.02
2017-01-07 20.02
2017-01-08 20.02
2017-01-09 20.02
2017-01-10 20.05
R ile Finansal Verileri İçe Aktarma ve Yönetme

Eksik değerleri doldurma

merge(irregular, regular_xts, fill = na.locf)
           Price
2017-01-02 20.01
2017-01-03 20.01
2017-01-04 20.02
2017-01-05 20.02
2017-01-06 20.02
2017-01-07 20.02
2017-01-08 20.02
2017-01-09 20.02
2017-01-10 20.05
R ile Finansal Verileri İçe Aktarma ve Yönetme

Hadi pratik yapalım!

R ile Finansal Verileri İçe Aktarma ve Yönetme

Preparing Video For Download...