我想根据数据框列中的出现次数创建一个饼图。但是,在制作饼图之前,我想删除 5 个单词。我有一个数据框,我可以使用以下方法删除这些行:
subset(df, tag != "rubbish")
但是,如果我然后使用绘图
pie(table(df$tag)
垃圾仍然出现在饼图中,但实例为零。
table(df$tag)
在子集之前给我一些类似的东西:tag1 3
tag2 7
rubbish 9
之后:
tag1 3
tag2 7
rubbish 0
无论如何要完全清除垃圾而不用 table() 返回零?我试过
table(df$tag, exclude="rubbish")
但我想删除的标签不止 1 个。
最佳答案
我认为问题在于df$tag
是一个因子或分类变量。从因子中删除某个类别不会更改与该因子关联的水平。 table
迭代与因子相关的水平。即使级别为空 table
这样做,因此 rubbish 0
.解决方案是在删除标签后重新创建因子:
subset(df, tag != "rubbish")
levels(df$tag)
df$tag = factor(df$tag)
levels(df$tag)
table(df$tag)
我认为这应该可以解决您的问题。
关于r - 完全删除 R 中的数据帧行。停止 table() 为删除的数据返回 0,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9785068/