目的は、データ フレームの列を変換することです。次に例を示します。
df <- data.frame( fact=c("dog",2,"NA",0,"cat",1,"Cat"),
value=c(4,2,6,0,9,1,3) ); df$fact <- as.factor(df$fac)
func <- function(data,fac,val){
data <- data %>%
mutate_(fac= interp(~tolower(fac), fac=as.name(fac)) ) %>%
mutate_(val= interp(~ifelse(fac=='cat',1*val,
ifelse(fac=='dog',2*val,0)), fac=as.name(fac), val=as.name(val)))
return(data) }
呼び出し:
new.df <- func(df,"fact","value")
fact value fac val
1 dog 4 dog 8
2 2 2 2 0
3 NA 6 na 0
4 0 0 0 0
5 cat 9 cat 9
6 1 1 1 0
7 Cat 3 cat 0
2 つの問題があります: (1)- "Cat" に関連付けられた値が false です。3*1=3 (2) である必要があります。呼び出しは、理想的にはdf
、変換された変数fact
とvalue
変数を含む元の data.frame を返します。
何かご意見は?君たちありがとう。
編集: には、 およびに対して行われた操作の影響を受けないようにする必要があるdf
別の列があることに注意してください。third
fact
value