0

R 新手。我有一个 data.frame

'data.frame':   2070 obs. of  5 variables:
 $ id   : int  16625062 16711130 16625064 16668358 16625066 16711227 16711290 16668746     16711502 16625494 ...
 $ subj : Factor w/ 3 levels "L","M","S": 1 1 1 1 1 1 1 1 1 1 ...
 $ grade: int  4 6 4 5 4 6 6 5 6 4 ...
 $ score: int  225 225 0 225 225 375 375 125 225 125 ...
 $ level: logi  NA NA NA NA NA NA ...

和一个名为查找的命名数字列表

 Named num [1:12] 12 19 20 26 31 32 49 67 72 73 ...
 - attr(*, "names")= chr [1:12] "0" "50" "100" "125" ...

我想找到一种方法来通过查找查找列表中的值来更新数据框“级别”列,将数据框“分数”列与查找列表中的数字名称相匹配。换句话说,数据框中的分数值用于在查找列表中查找数字(将进入级别列)。

所以......如果有人明白我的意思......请帮忙。

谢谢罗本

4

1 回答 1

2

你应该能够做到这一点(假设你的数据框被称为d):

d$level = as.numeric(lookup[as.character(d$score)])

例如:

lookup = list(1, 2, 3, 4)
names(lookup) = c("0", "50", "100", "150")

d = data.frame(score=c(50, 150, 0, 0), level=NA)
d$level = as.numeric(lookup[as.character(d$score)])
print(d)
#   score level
# 1    50     2
# 2   150     4
# 3     0     1
# 4     0     1
于 2012-09-14T15:04:49.967 回答