相关疑难解决方法(0)

对数据框中组内的行进行编号

使用与此类似的数据框:

set.seed(100)  
df <- data.frame(cat = c(rep("aaa", 5), rep("bbb", 5), rep("ccc", 5)), val = runif(15))             
df <- df[order(df$cat, df$val), ]  
df  

   cat        val  
1  aaa 0.05638315  
2  aaa 0.25767250  
3  aaa 0.30776611  
4  aaa 0.46854928  
5  aaa 0.55232243  
6  bbb 0.17026205  
7  bbb 0.37032054  
8  bbb 0.48377074  
9  bbb 0.54655860  
10 bbb 0.81240262  
11 ccc 0.28035384  
12 ccc 0.39848790  
13 ccc 0.62499648  
14 ccc 0.76255108  
15 ccc 0.88216552 
Run Code Online (Sandbox Code Playgroud)

我想在每个组中添加一个带编号的列.这样做显然不是使用R的权力:

 df$num <- 1  
 for (i in 2:(length(df[,1]))) {  
   if (df[i,"cat"]==df[(i-1),"cat"]) { …
Run Code Online (Sandbox Code Playgroud)

r dataframe r-faq

136
推荐指数
6
解决办法
8万
查看次数

回收和分配功能(`split <-`)

有人可以解释一下这一行R代码是如何工作的吗?

split(dat, f) <- lapply(split(dat, f), max)
Run Code Online (Sandbox Code Playgroud)

我认为这只是一个回收规则,但实际上我无法理解.

数据示例:

dat <- c(1, 2, 3, 100, 200, 300)
f <- as.factor(c("a", "a", "b", "a", "b", "b"))
split(dat, f) <- lapply(split(dat, f), max)
dat
[1] 100 100 300 100 300 300
Run Code Online (Sandbox Code Playgroud)

代码执行我想做的事情(按组分配最大值),但问题是这是如何完成的?

syntax functional-programming r

16
推荐指数
2
解决办法
394
查看次数

观察人数分组

在RI中有一个数据帧,其中观察由几个值描述,其中一个值是一个因子.我已经按照这个因素对数据集进行了排序,并希望添加一个列,在该列中,我将在每个级别的因子上获得一些观察结果,例如

factor   obsnum
a        1
a        2
a        3
b        1
b        2
b        3
b        4
c        1
c        2
...
Run Code Online (Sandbox Code Playgroud)

在SAS中,我使用以下内容:

data logs.full;
    set logs.full;
    count + 1;
    by cookie;
    if first.cookie then count = 1;
run;
Run Code Online (Sandbox Code Playgroud)

我怎样才能在R中实现这一目标?

谢谢,

r sas

7
推荐指数
2
解决办法
7147
查看次数

标签 统计

r ×3

dataframe ×1

functional-programming ×1

r-faq ×1

sas ×1

syntax ×1