我的数据如下:
service,rating_1,rating_2,rating_3,rating_4,rating_5
renew_patent,0,0,1,2,11
apply_benefit,21,20,121,828,1744
apply_employment_tribunal,0,0,0,0,0
我希望R为每行打印一个直方图,列为直方图的条形。
到目前为止我已经知道了这一点:
require(lattice)
data <- read.csv("test.csv", header = TRUE)
colors = c('red', 'orange', 'yellow', 'blue', 'green')
barchart(rating_1+rating_2+rating_3+rating_4+rating_5 ~ service, data=data,
auto.key=list(space='right'), scales=list(x=list(rot=45)),
ylab="Percentage of total", col=colors)
它正常工作,但它按字母顺序打印直方图,而不是按CSV文件中指定的顺序打印直方图。
如何更改此设置以使条形符合CSV文件中的顺序,首先显示renew_patent
?
答案 0 :(得分:6)
您需要在数据本身中指定级别的顺序,然后barchart
将执行您想要的操作。
一种选择是运行如下代码:
data$service <- factor(data$service, levels=unique( as.character(data$service) ) )
在致电barchart
之前。