我想用自己的方式对分类变量进行排序。我已经将我的数据集分为"1-5“、"6-10”、"11-20“等类别。">251“等等。如果绘制变量或将它们显示在表格中,则图例的顺序在标签中的顺序是“混乱的”。
这并不奇怪,因为R不知道这些无序变量实际上是有序的。有没有办法将手动定义的序列附加到它们上?
如有任何建议,请提前向我咨询!
发布于 2010-07-20 20:17:57
当您绘制分类变量时,它们被存储为(或转换为)factor。它们在绘图中出现的顺序取决于因子的级别。
您可能希望使用cut创建您的组。例如:
dfr <- data.frame(x = runif(100, 1, 256))
dfr$groups <- cut(dfr$x, seq(1, 256, 5))这个问题也与another recent SO question非常相似。
发布于 2010-07-21 02:11:49
当我想要手动指定一个因子的不同顺序时(繁琐,但有时是必要的),我会这样做:
> ## a factor
> x <- factor(letters[1:3])
> ## write out levels with dput
> dput(levels(x))
c("a", "b", "c")
> ## copy, paste, modify and use factor again. e.g.
> x <- factor(x, levels=c("b", "a", "c"))
> x
[1] a b c
Levels: b a c发布于 2010-07-21 11:40:08
我喜欢使用split来做这类事情。
向量= runif(10)
vect.categories = c(rep(LETTERS1,5),rep(LETTERS2,3),rep(LETTERS5,2))
category.list =拆分(矢量,vect.categories)
……
可能没有关系,但我想给你提个建议。
https://stackoverflow.com/questions/3289635
复制相似问题