2

ここに小さな例があります:

A <- c(1,1,1,1, 0, 0, 0, 2,2,2)
B <- c(1,1,1,1, 0, 0, 0, 0,2,2)
C <- c(1,1,3,3, 0,0, 2,2,2, NA)
myd <- data.frame (A, B, C)

「prod」(prod(myd $ myvar、na.rm = TRUE)という関数を適用する必要があります。適用する前に、0の数を数える必要があります。

(1) If number zeros are equal to or less than 3, I need to replace with NA
    myd$A[myd$A ==0] <- NA

(2) If  number of zeros are greater than 3, no replacement action need to be done.
   myd$B[myd$B ==0] <- 0 

ゼロを数え、条件を適用して結果を得るにはどうすればよいですか。

編集:上記のデータセットでは、AとCは条件1とBの条件2を満たしています。

4

1 に答える 1

3

このようなものをお探しですか?

f <- function(X) {
    if(sum(X==0, na.rm=TRUE) <= 3) X[X==0] <- NA
    X
}

data.frame(lapply(myd, f))
#     A B  C
# 1   1 1  1
# 2   1 1  1
# 3   1 1  3
# 4   1 1  3
# 5  NA 0 NA
# 6  NA 0 NA
# 7  NA 0  2
# 8   2 0  2
# 9   2 2  2
# 10  2 2 NA
于 2012-06-13T17:03:41.897 に答える