用NA替换不需要的因子级别值

时间:2012-04-08 18:07:44

标签: r na r-factor

我有一个包含空白缺失值和NA的大型数据框。 执行摘要(因子(df $ col))给我一些像

A  
123  
B  
50000  

90000  
C  
26000
NA's  
12476  

(注意50000之后的空白。)
并且sum(is.na(df$col))是12476,与NA的数量相同,但我希望它是空白和NA的总和。 我试图通过制作为空白创建一个级别 levels(df$col) <- c("A", "B", "Blank", "C")
然后尝试df$col <- factor(df$col, exclude="Blank")并说它生成NA但我的输出是相同的。有没有人知道如何根据因子水平创建NA或者有更好的解决方案来替换缺失的值?我认为问题可能是空白不止一个空白字符,所以它们没有变成NA,但我不知道如何确认。

1 个答案:

答案 0 :(得分:2)

试试这个:

df <- data.frame(a=11:18, col=c("C", "", "A", NA, "A", "", "C", NA))
levels(df$col) # ""  "A" "C"
sum(is.na(df$col)) # 2

df$col <- factor(df$col, levels=LETTERS[1:3])
levels(df$col) # "A" "B" "C"
sum(is.na(df$col)) # 4

由于新级别不包含空白(“”),因此所有空白都将变为NA。