【发布时间】:2020-04-06 11:40:59
【问题描述】:
我想根据我的数据创建一个矩阵。我的数据由两列组成,日期和我对每个日期的观察。我希望矩阵将年作为行,将天作为列,例如:
17 18 19 20 ... 31
1904 x11 x12 ...
1905
1906
.
.
.
2019
本例中的天数为每年 12 月。我希望缺失值等于 NA。
这是我的数据示例:
> head(cdata)
# A tibble: 6 x 2
Datum Snödjup
<dttm> <dbl>
1 1904-12-01 00:00:00 0.02
2 1904-12-02 00:00:00 0.02
3 1904-12-03 00:00:00 0.01
4 1904-12-04 00:00:00 0.01
5 1904-12-12 00:00:00 0.02
6 1904-12-13 00:00:00 0.02
我认为我需要做的第一件事是将日期拆分为年、月和日(欧洲格式,YYYY-MM-DD)所以我这样做并去掉了日期列(那个说Datum) 并且也摆脱了不相关的日子,即
cdata %>%
dplyr::mutate(year = lubridate::year(Datum),
month = lubridate::month(Datum),
day = lubridate::day(Datum))
select(cd, -c(Datum))
cu <- cd[which(cd$day > 16
& cd$day < 32
& cd$month == 12),]
现在看起来像这样:
> cu
# A tibble: 1,284 x 4
Snödjup year month day
<dbl> <dbl> <dbl> <int>
1 0.01 1904 12 26
2 0.01 1904 12 27
3 0.01 1904 12 28
4 0.12 1904 12 29
5 0.12 1904 12 30
6 0.15 1904 12 31
7 0.07 1906 12 17
8 0.05 1906 12 18
9 0.05 1906 12 19
10 0.04 1906 12 20
# … with 1,274 more rows
现在我需要将我的数据放入一个缺失值为 NA 的矩阵中。有没有办法做到这一点?
【问题讨论】:
-
那么几个月呢?您想在哪里获取月份信息?
-
月份无关紧要,因为所有的日子都是从 12 月开始的