【问题标题】:R removing data frame row according to a vector valueR根据向量值删除数据框行
【发布时间】:2015-01-30 01:12:21
【问题描述】:

我需要根据另一个数据框中的值从数据框中删除一行。我相信我在我的公式上做了一些愚蠢的事情,但我根本看不到它是什么,所以我请求你的帮助。

我有这个数据框,我想从中删除一些行:

> Teste
   Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 Q10 Q11 Q12 Q13 Q14 Q15 Q16 Q17 Q18 Q19 Q20 Q21
1   5  4  4  4  6  6  7  6  4   6   6   6   4   4   4   4   6   7   4   4   6
2   5  4  4  5  5  5  5  5  5   5   7   5   4   3   1   6   6   5   6   7   7
3   4  5  4  4  5  4  5  4  5   4   5   4   5   4   5   4   5   4   5   4   5
4   5  5  7  7  4  6  6  6  7   7   6   7   7   6   6   7   4   7   6   6   7
5   6  1  7  6  7  7  7  7  7   7   6   7   2   2   3   6   3   7   7   7   7
6   4  4  3  3  4  5  4  3  4   7   6   6   4   4   6   4   5   7   6   6   7
7   1  1  7  7  7  3  7  6  2   7   6   7   6   7   4   7   7   7   7   4   7
8   5  5  6  7  6  6  4  4  5   6   7   6   4   4   5   3   3   7   6   6   7
9   5  4  7  4  7  6  6  7  5   7   6   7   4   5   4   7   5   7   7   7   7
10  6  4  7  4  7  6  6  7  5   7   7   7   4   4   3   6   4   7   7   6   7
11  7  7  7  7  7  7  7  7  7   7   7   7   7   7   7   7   7   7   7   7   7

> dput(Teste)
structure(list(Q1 = c(5L, 5L, 4L, 5L, 6L, 4L, 1L, 5L, 5L, 6L, 
7L), Q2 = c(4L, 4L, 5L, 5L, 1L, 4L, 1L, 5L, 4L, 4L, 7L), Q3 = c(4L, 
4L, 4L, 7L, 7L, 3L, 7L, 6L, 7L, 7L, 7L), Q4 = c(4L, 5L, 4L, 7L, 
6L, 3L, 7L, 7L, 4L, 4L, 7L), Q5 = c(6L, 5L, 5L, 4L, 7L, 4L, 7L, 
6L, 7L, 7L, 7L), Q6 = c(6L, 5L, 4L, 6L, 7L, 5L, 3L, 6L, 6L, 6L, 
7L), Q7 = c(7L, 5L, 5L, 6L, 7L, 4L, 7L, 4L, 6L, 6L, 7L), Q8 = c(6L, 
5L, 4L, 6L, 7L, 3L, 6L, 4L, 7L, 7L, 7L), Q9 = c(4L, 5L, 5L, 7L, 
7L, 4L, 2L, 5L, 5L, 5L, 7L), Q10 = c(6L, 5L, 4L, 7L, 7L, 7L, 
7L, 6L, 7L, 7L, 7L), Q11 = c(6L, 7L, 5L, 6L, 6L, 6L, 6L, 7L, 
6L, 7L, 7L), Q12 = c(6L, 5L, 4L, 7L, 7L, 6L, 7L, 6L, 7L, 7L, 
7L), Q13 = c(4L, 4L, 5L, 7L, 2L, 4L, 6L, 4L, 4L, 4L, 7L), Q14 = c(4L, 
3L, 4L, 6L, 2L, 4L, 7L, 4L, 5L, 4L, 7L), Q15 = c(4L, 1L, 5L, 
6L, 3L, 6L, 4L, 5L, 4L, 3L, 7L), Q16 = c(4L, 6L, 4L, 7L, 6L, 
4L, 7L, 3L, 7L, 6L, 7L), Q17 = c(6L, 6L, 5L, 4L, 3L, 5L, 7L, 
3L, 5L, 4L, 7L), Q18 = c(7L, 5L, 4L, 7L, 7L, 7L, 7L, 7L, 7L, 
7L, 7L), Q19 = c(4L, 6L, 5L, 6L, 7L, 6L, 7L, 6L, 7L, 7L, 7L), 
Q20 = c(4L, 7L, 4L, 6L, 7L, 6L, 4L, 6L, 7L, 6L, 7L), Q21 = c(6L, 
7L, 5L, 7L, 7L, 7L, 7L, 7L, 7L, 7L, 7L)), .Names = c("Q1", 
"Q2", "Q3", "Q4", "Q5", "Q6", "Q7", "Q8", "Q9", "Q10", "Q11", 
"Q12", "Q13", "Q14", "Q15", "Q16", "Q17", "Q18", "Q19", "Q20", 
"Q21"), row.names = c(NA, 11L), class = "data.frame")

我的标准是根据该向量中的值删除行:

> Teste2
   apply.TiposMotivA.1.11.....1..function.x..sum.x....Mode.x...
1                                                            10
2                                                            10
3                                                            11
4                                                             9
5                                                            12
6                                                             8
7                                                            12
8                                                             7
9                                                            10
10                                                            9
11                                                           21
> dput(Teste2)
structure(list(apply.TiposMotivA.1.11.....1..function.x..sum.x....Mode.x... = c(10L, 
10L, 11L, 9L, 12L, 8L, 12L, 7L, 10L, 9L, 21L)), .Names = "apply.TiposMotivA.1.11.....1..function.x..sum.x....Mode.x...", row.names = c ("1", 
"2", "3", "4", "5", "6", "7", "8", "9", "10", "11"), class = "data.frame")

必须删除 Teste 中 Teste2 中对应值除以 0.21 小于 0.762 的任何行。 我正在尝试通过使用此命令来达到此目的,但出现以下错误:

> Teste3 <- Teste[!apply(Teste2,1,function(x) {any((x / 0.21) >= 0.762)}),]
Error in apply(Teste2, 1, function(x) { : 
dim(X) must have a positive length

任何帮助将不胜感激!

【问题讨论】:

  • 您的Teste2 是一个向量。你不能在向量上使用apply
  • 天啊,我知道我应该遗漏一些东西。好的,我已将其转换为数据框
  • 您不需要将其转换为data.frame。一个向量就足够了。

标签: r


【解决方案1】:

也许我遗漏了一些东西,但在我看来你只需要:

Teste[Teste2/.21 < .762,]

如果您希望 Teste2 成为数据框:

Teste[Teste2[,1]/.21 < .762,]

【讨论】:

  • 感谢 Marat,但这返回了零行
  • 嗯,这是正确的结果,因为 Teste2 中的每个值除以 0.21 都大于 0.762。
  • 该死,我又犯了一个愚蠢的错误。我需要除以 21,而不是 0.21!现在它就像一个魅力,非常感谢!
猜你喜欢
  • 1970-01-01
  • 2022-08-03
  • 1970-01-01
  • 2016-05-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多