在R编程中,我尝试执行以下操作:
df
A B Category
0.9 0.85 A
0.7 0.75 B
0.8 0.90 B
CSF <- function(df, type) {
switch(type,
"A" = qnorm(df$A, 0 , 1),
"B" = qnorm(df$B, 0 , 1)
)
}
df<-data.frame(df, value = CSF(df,df$category))
期望的结果:
df
A B Category Value
0.9 0.85 A qnorm(0.9, 0, 1)*
0.7 0.75 B qnorm(0.75, 0, 1)*
0.8 0.90 B qnorm(0.9, 0, 1)*
*:真实值
错误消息:EXPR必须是长度为1的向量
答案 0 :(得分:3)
您可以使用ifelse
功能:
df$Value <- ifelse(df$Category=="A",qnorm(df$A,0,1),qnorm(df$B,0,1))
答案 1 :(得分:0)
对于更复杂的类别排列,我建议将其分解为多个语句。像
这样的东西df$CSF <- NA
df.split <- split(df, df$Category)
df.split$A$CSF <- qnorm(df.split$A$A, 0, 1)
df.split$B$CSF <- qnorm(df.split$B$B, 0, 1)
...
然后将它们合并在一起
df <- unsplit(df.split, df$Category)
它并没有“单一表达”的优雅。但它也避免了大量的嵌套来完成任务。您可以使用within
简化单个表达式:
df.split$A <- within(df.split$A, CSF <- qnorm(A, 0 0))