gpt4 book ai didi

r - 如何将 15 分钟的数据转换为日期时间格式的时间序列,以便我可以使用 quantmod 绘制它?

转载 作者:行者123 更新时间:2023-12-04 10:52:39 26 4
gpt4 key购买 nike

所以我得到了这些数据,我想将其转换为 xts,以便我可以使用 quantmod 绘制它。 (是15m图)

 > sample
Date Open High Low Close Vol.at.Price Volume
515 2016-06-15 pm 1:15:00 1.7381 1.7600 1.710 1.7399 1.7399 176000
516 2016-06-15 pm 1:30:00 1.7389 1.7400 1.725 1.7350 1.7350 152900
517 2016-06-15 pm 1:45:00 1.7350 1.7650 1.720 1.7550 1.7550 179900
518 2016-06-15 pm 2:00:00 1.7550 1.7600 1.740 1.7500 1.7500 130800
519 2016-06-15 pm 2:15:00 1.7550 1.7800 1.745 1.7800 1.7800 188400
520 2016-06-15 pm 2:30:00 1.7800 1.7899 1.730 1.7300 1.7300 256700
521 2016-06-15 pm 2:45:00 1.7300 1.7800 1.730 1.7664 1.7664 151900
522 2016-06-15 pm 3:00:00 1.7600 1.7700 1.740 1.7600 1.7600 74100
523 2016-06-15 pm 3:15:00 1.7501 1.8000 1.750 1.7850 1.7850 232300
524 2016-06-15 pm 3:30:00 1.7900 1.8200 1.760 1.7600 1.7600 183300
525 2016-06-15 pm 3:45:00 1.7600 1.7700 1.730 1.7400 1.7400 151600
526 2016-06-15 pm 4:00:00 1.7400 1.7599 1.650 1.7150 1.7150 443500
527 2016-06-15 pm 4:15:00 1.7100 1.7100 1.710 1.7100 1.7100 4628
528 2016-06-15 pm 6:30:00 1.7100 1.7100 1.710 1.7100 1.7100 2000
529 2016-06-15 pm 7:00:00 1.6900 1.6900 1.680 1.6900 1.6900 1050
530 2016-06-15 pm 8:00:00 1.6900 1.6900 1.690 1.6900 1.6900 100
> class(sample)
[1] "data.frame"

起初,我认为使用 xts 函数可以完成这项工作,但后来我意识到它只是削减了分钟部分。

> sampled.after<-xts(sample[2:ncol(sample)],as.Date(sample$Date))
> sampled.after
Open High Low Close Vol.at.Price Volume
2016-06-15 1.7381 1.7600 1.710 1.7399 1.7399 176000
2016-06-15 1.7389 1.7400 1.725 1.7350 1.7350 152900
2016-06-15 1.7350 1.7650 1.720 1.7550 1.7550 179900
2016-06-15 1.7550 1.7600 1.740 1.7500 1.7500 130800
2016-06-15 1.7550 1.7800 1.745 1.7800 1.7800 188400
2016-06-15 1.7800 1.7899 1.730 1.7300 1.7300 256700
2016-06-15 1.7300 1.7800 1.730 1.7664 1.7664 151900
2016-06-15 1.7600 1.7700 1.740 1.7600 1.7600 74100
2016-06-15 1.7501 1.8000 1.750 1.7850 1.7850 232300
2016-06-15 1.7900 1.8200 1.760 1.7600 1.7600 183300
2016-06-15 1.7600 1.7700 1.730 1.7400 1.7400 151600
2016-06-15 1.7400 1.7599 1.650 1.7150 1.7150 443500
2016-06-15 1.7100 1.7100 1.710 1.7100 1.7100 4628
2016-06-15 1.7100 1.7100 1.710 1.7100 1.7100 2000
2016-06-15 1.6900 1.6900 1.680 1.6900 1.6900 1050
2016-06-15 1.6900 1.6900 1.690 1.6900 1.6900 100

如何将其转换为时间序列以便绘制蜡烛图?

最佳答案

as.Date 仅返回时间戳的日期部分。使用 as.POSIXct 来保留完整的时间戳。此外,您需要提供一个 format 参数,以便 as.POSIXct 理解您的日期格式。如果没有 format 参数,它只是将时间戳截断为日期部分。下面是几个例子:

as.Date 仅返回日期

as.Date("2016-06-15 pm 1:15:00")  
[1] "2016-06-15"  

as.POSIXct 没有 format 参数返回日期加上默认时区

as.POSIXct("2016-06-15 pm 1:15:00")  
[1] "2016-06-15 PDT"

将正确的格式添加到as.POSIXct以获得完整的时间戳

as.POSIXct("2016-06-15 pm 1:15:00", format="%Y-%m-%d %p %I:%M:%S")
[1] "2016-06-15 13:15:00 PDT"

有关如何解释上面的 format 参数的详细信息,请参阅 strptime 的帮助。

将正确的formattz添加到as.POSIXct以获得完整的时间戳和正确的时区

请注意,as.POSIXct 还将我的本地时区添加到结果 (PDT) 中。因此,您可能还应该添加一个时区参数以确保应用正确的时区(尤其是当您有来自不同时区的交易所的报价时)。例如:

as.POSIXct("2016-06-15 pm 1:15:00", format="%Y-%m-%d %p %I:%M:%S", tz="America/New_York")
[1] "2016-06-15 13:15:00 EDT" 

关于r - 如何将 15 分钟的数据转换为日期时间格式的时间序列,以便我可以使用 quantmod 绘制它?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37865630/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com