r - 如果我的原始数据集中不存在这些日期,如何将某些日期的 geom_vline 添加到我的绘图中?
问题描述
我想做的事情的要点是叠加锁定开始的日期和结束的日期。我的数据包含每周销售数据,但不包含锁定开始或结束的日期,因此当我使用“lockdown.end.dates <- which(Unit.sales$Date %in%lockdown.end.dates)”代码它将我的“locdown.end.dates”向量变成一个空对象,就像在我附加的图像中看到的那样。**
这就是我的数据的样子
当我尝试创建一个包含未包含在我的 unit.sales 数据框中的日期的向量时,这就是我的对象窗格的外观。请注意,对于lockdown.start.date,我已经调整了日期,使它们与我在unit.sales 数据框中的日期重叠
####Install Packages####
library(fpp2)
library(dplyr)
library(zoo)
library(xts)
library(ggplot2)
######Load data########
Unit.sales <- structure(list(
Date = c(
"30/03/2019",
"06/04/2019",
"13/04/2019",
"20/04/2019",
"27/04/2019",
"04/05/2019",
"11/05/2019",
"18/05/2019",
"25/05/2019",
"01/06/2019"
),
Units = c(
967053.4,
633226.9,
523264,
473914.2,
418087.5,
504342.2,
477819,
415650,
406972.3,
429791.4
)
),
row.names = c(NA, 10L),
class = "data.frame")
######Convert date column to date format########
Unit.sales$Date <- as.Date(Unit.sales$Date, format='%d/%m/%Y')
######Convert data frame to time series object#####
unit.sales.ts <- xts(Unit.sales$Units, Unit.sales$Date)
class(unit.sales.ts)
#######Visualize data######
unit.sales.plot <- Unit.sales %>% ggplot(aes(x=Date, y=Units)) +
geom_line() +
scale_x_date(date_labels="%b %y",date_breaks ="2 month") +
labs(title = "Linechart of unit sales")
#Create objects containing the lockdown dates#
lockdown.start.dates <- as.Date(c("2020-03-28", "2020-11-07", "2021-01-09"))
lockdown.start.dates <- which(Unit.sales$Date %in% lockdown.start.dates)
lockdown.end.dates <- as.Date(c("2020-06-15", "2020-11-05", "2021-04-12"))
lockdown.end.dates <- which(Unit.sales$Date %in% lockdown.end.dates)
#Add lockdown dates to the unit.sales.plot#
unit.sales.plot +
geom_vline(xintercept = as.numeric(Unit.sales$Date[lockdown.start.dates,]),
col = "red", lwd = 3)
解决方案
推荐阅读
- java - %Like% 在spring JpaRepository中查询N个字段
- .net - 在 Delphi 7 中调用 C++ DLL 函数
- java - Keycloak 无法获取访问令牌
- javascript - 如何更新数组列表排序?
- css - 如何并行启动 2 个动画
- ios - Swift - 执行 segue 时视图控制器不会取消初始化
- python - 使用 Python 读取堆叠标题 Excel 表
- arrays - mongodb 在嵌套数组或列表中查找
- jmeter - 无法通过 JMeter 登录 Salesforce 应用程序
- node.js - PEM 证书给出“错误标签”或“标题太长”错误