如何解决使用rep函数时,无效的'times'参数
我正在尝试向数据框添加一列,并且正在使用rep()函数。为什么第一行有效,但下一行无效?
> S_Grime$Græsning=rep(1:2,50:49)
> R_Grime$Græsning=rep(1:2,34:27)
Error in rep(1:2,34:27) : invalid 'times' argument
我的数据:
> head(S_Grime)
# A tibble: 6 x 3
Feltnummer value Græsning
<dbl> <dbl> <int>
1 1 6.26 1
2 2 5.72 1
3 3 8.74 1
4 4 5.33 1
5 5 6.23 1
6 6 8.67 1
> head(R_Grime)
# A tibble: 6 x 2
Feltnummer value
<dbl> <dbl>
1 2 2
2 3 2
3 4 2
4 5 2
5 7 2
6 11 2
> str(R_Grime)
tibble [61 x 2] (S3: tbl_df/tbl/data.frame)
$ Feltnummer: num [1:61] 2 3 4 5 7 11 12 13 14 15 ...
$ value : num [1:61] 2 2 2 2 2 2 2 2 4 2 ...
> str(S_Grime)
tibble [99 x 3] (S3: tbl_df/tbl/data.frame)
$ Feltnummer: num [1:99] 1 2 3 4 5 6 7 8 9 10 ...
$ value : num [1:99] 6.26 5.72 8.74 5.33 6.23 ...
$ Græsning : int [1:99] 1 1 1 1 1 1 1 1 1 1 ...
解决方法
来自?rep.int
:
如果
times
由一个整数组成,则结果由 整个输入重复了很多次。如果times
是相同的向量 长度为x(每个复制后),结果由x[1]
组成 重复times[1]
次,x[2]
重复times[2]
次,依此类推
times
既不是1也不是x的长度是不确定的。
如果您期望34 1s,然后是27 2s,则应该执行rep(1:2,c(34,27))
。如果您希望将1:2
回收到与34:27
相同的长度,则需要特别指定rep(rep(1:2,length.out=length(34:27)),34:27)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。