r - 从 R 中的数据集创建矩阵

标签 r matrix

我想根据我的数据创建一个矩阵。我的数据由两列组成:日期和我对每个日期的观察结果。我希望矩阵将年份作为行,将日期作为列,例如:

      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),并且还删除了不相关的日期,即 < 17 的日期。

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 的矩阵中。有办法做到这一点吗?

最佳答案

基本 R 方法,使用 by

r <- `colnames<-`(do.call(rbind, by(dat, substr(dat$date, 1, 4), function(x) x[2])), 1:31)
r[,17:31]
#         17    18    19   20    21    22    23   24    25    26    27    28   29    30   31
# 1904 -0.28 -2.66 -2.44 1.32 -0.31 -1.78 -0.17 1.21  1.90 -0.43 -0.26 -1.76 0.46 -0.64 0.46
# 1905  1.44 -0.43  0.66 0.32 -0.78  1.58  0.64 0.09  0.28  0.68  0.09 -2.99 0.28 -0.37 0.19
# 1906 -0.89 -1.10  1.51 0.26  0.09 -0.12 -1.19 0.61 -0.22 -0.18  0.93  0.82 1.39 -0.48 0.65

玩具数据

set.seed(42)
dat <- do.call(rbind, lapply(1904:1906, function(x) 
  data.frame(date=seq(ISOdate(x, 12, 1, 0), ISOdate(x, 12, 31, 0), "day" ),
             value=round(rnorm(31), 2))))

关于r - 从 R 中的数据集创建矩阵,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61058960/

相关文章:

c++ - 如何创建用于添加两个矩阵的函数?它会返回什么?

Python Numpy - 将非常小的数字视为零

r - R-从底部和行方向将矩阵转换为矢量

r - 是否可以让RStudio显示自定义函数的函数参数和描述?

r - Betareg 导致内存分配问题

r - 通过循环在 R 中绘制图形并像 jpeg 一样保存

haskell - 计算 GF(2) 中 rref 的算法?

c - 二维字符和数字数组

r - 如何在R中按名称模式删除列?

r - 并排输出维恩 gList 对象和网络图