我有一个名为d
的列表,如下所示:
V1
是一个0到50之间的整数
V2
是1500 - 1800年的真实集
V3
是1到50
总共,该列表包含5100个对象
现在我想绘制V2
的直方图,V1
=某个数字(0,1或10等)
我尝试了不同的方法:
factor(d$V1)
qplot(V2, data=d, V1 = 1) --> not successful
d.subset <- subset(d, d$V1 = 1) --> not successful
我真的很生气。检查d$V1
的特征但发现没什么奇怪的。有人可以帮帮我吗?
is.factor(d$V1)
[1] TRUE
str(d$V1) Factor w/ 51 levels "1","2","3","4",..: 1 2 3 4 5 6 7 8 9 10 ...
levels(d$V1)
[1] "1" "2" "3" "4" "5" "6" "7" "8" "9" "10" "11" "12" "13" "14" "15" "16" "17" "18" "19"
[20] "20" "21" "22" "23" "24" "25" "26" "27" "28" "29" "30" "31" "32" "33" "34" "35" "36" "37""38"
[39] "39" "40" "41" "42" "43" "44" "45" "46" "47" "48" "49" "50" "51"
答案 0 :(得分:2)
更改行:
d.subset <- subset(d, d$V1 = 1)
到
d.subset <- subset(d, V1 == 1)
注意double等于(==
)表示逻辑运算符。 =
用于分配,不会对数据框进行子集化。
最后,如果您想获得因子的"1"
级别(可能与数字1
不同),您可能需要将1放在引号中。
d.subset <- subset(d, V1 == "1")