我试图为我的数据x计算每一列的和。
"Error in colSums(x, na.rm = T) : invalid 'na.rm' argument"为什么na.rm参数在这种情况下不起作用?困惑..。
x <- cbind(x1 = 3, x2 = c(4:1, 2:5))
x[3, ] <- NA; x[4, 2] <- NA
rowSums(x)
colSums(x, na.rm=T)发布于 2014-03-10 01:40:49
我可以通过将T的通常值重写为等于NA来重新创建您的bug。
> T=NA
> colSums(all,na.rm=T)
Error in colSums(all, na.rm = T) : invalid 'na.rm' argument所以很有可能,你(或者一个有趣的同事?)将代码中的变量T定义为等于NA。要撤消它,只需键入:
T=TRUE或更好:
rm(T)永远不要忘记,R并不真正了解T => --它只是在启动时为方便而定义的速记,仅此而已。
发布于 2014-03-10 01:52:34
您会得到一个错误,因为T的值已更改为一个不能解释为逻辑(TRUE或FALSE)的参数,该参数可以是NA或字符。在我看来,使用T和F是一个坏习惯。为了避免错误:
colSums(x, na.rm=TRUE)TRUE (或FALSE)不能作为保留字被覆盖。
只是为了好玩,你可以试着:
T = FALSE
F = TRUE
colSums(x, na.rm=T)
colSums(x, na.rm=F)https://stackoverflow.com/questions/22290737
复制相似问题