r - 完全删除 R 中的数据帧行。停止 table() 为删除的数据返回 0

标签 r dataframe subset pie-chart

我想根据数据框列中的出现次数创建一个饼图。但是,在制作饼图之前,我想删除 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/

相关文章:

Python json API 格式转数据框

java - 如何在 R 中加载 apache poi 库?

linq - LINQ风格的R中的数据处理

r - 成对组合向量的元素

r - 在prop.table输出中附加%符号

r - 在 R data.frame 中,将行名提升为实际列

python - 数据框用其他行替换行

ruby - 如何从数组中提取特定元素?

r - 基于列名称的部分匹配的子集数据

r - 仅对时间序列中的工作日进行子集化