ggplot2 学习day2
2020-05-29 本文已影响0人
Silmarillion123
其实不需要去寻找数据,gcookbook 就有演示数据
1.条型图
非连续型:
> pg_mean
group weight
1 ctrl 5.032
2 trt1 4.661
3 trt2 5.526
>ggplot(pg_mean,aes(x=group,y=weight))+geom_bar(stat="identity")
data:image/s3,"s3://crabby-images/630a4/630a482efca6d8a545a5b8ec453efb5715226454" alt=""
ggplot(pg_mean,aes(x=group,y=weight))+geom_bar(stat="identity",width=0.5)
width可控制条形间距data:image/s3,"s3://crabby-images/a4dc3/a4dc35bde8ba0cb43a9bd623291f21c7e08f6cf9" alt=""
连续型:
若不加处理
ggplot(BOD,aes(x=Time,y=demand))+geom_bar(stat="identity")
data:image/s3,"s3://crabby-images/d2385/d23850c910d85a49349462d3bc6c6d86dc54f70a" alt=""
若转化为离散型
ggplot(BOD,aes(x=factor(Time),y=demand))+geom_bar(stat="identity")#用factor函数
data:image/s3,"s3://crabby-images/0dd3c/0dd3c8fd05031f63df15793da97d1ee608043a30" alt=""
花炮一点的话
ggplot(BOD,aes(x=factor(Time),y=demand))+geom_bar(stat="identity",fill="lightblue",colour="black")
data:image/s3,"s3://crabby-images/77a91/77a91250b36d02c54e75970eafaf3ec5f75d4419" alt=""
2.簇状条形图
ggplot(cabbage_exp,aes(x=Date,y=Weight,fill=Cultivar))+geom_bar(position = "dodge",stat="identity")
fill 指根据Cultivar这一个参数来分配颜色
position = "dodge" 使条形在水平方向上错开
data:image/s3,"s3://crabby-images/fbedd/fbedd8dee918b7c45a31deb10613e7c92f5304a5" alt=""
ggplot(cabbage_exp,aes(x=Date,y=Weight,fill=Cultivar))+geom_bar(position = "dodge",stat="identity",color="blue")+scale_fill_brewer(palette="Pastell")
最后一句为换一个调色盘
data:image/s3,"s3://crabby-images/61a91/61a9193f9c1a23bbec76d2d98020dc00da95336b" alt=""
3.频数条形图
ggplot(diamonds,aes(x=cut))+geom_bar()
data:image/s3,"s3://crabby-images/bc3b7/bc3b758787042a333b7b41229dabc1342bf8b0c7" alt=""
4.颜色改变示例
a<-subset(uspopchange,rank(Change)>40)#从小到大排,40名以后的
ggplot(a,aes(x=Abb,y=Change,fill=Region))+geom_bar(stat="identity")#基础版
data:image/s3,"s3://crabby-images/12978/129781a9883dbc2431467ecb46537b03e1126eff" alt=""
ggplot(a,aes(x=Abb,y=Change,fill=Region))+geom_bar(stat="identity")+geom_text(aes(label=Change),vjust=1.5,colour="yellow")
给条形增加数值,vjust正的在下,负的在上
data:image/s3,"s3://crabby-images/78bf5/78bf55ff5571bb5a35bd892320bd96ceb03cb10d" alt=""
ggplot(a,aes(x=Abb,y=Change,fill=Region))+geom_bar(stat="identity")+geom_text(aes(label=Change),vjust=-0.5,colour="black")
data:image/s3,"s3://crabby-images/a74a2/a74a2f14fbc02008221932bb096c815a917b0208" alt=""
ggplot(a,aes(x=Abb,y=Change,fill=Region))+geom_point(size=5)
这叫做cleverland点图
data:image/s3,"s3://crabby-images/ed326/ed326d309650495bdc8026aae46f273ee487d6b8" alt=""
ggplot(a,aes(x=reorder(Abb,Change),y=Change,fill=Region))+geom_bar(stat="identity",color="black")+scale_fill_manual(values=c("#669933","#FFCC66"))+xlab("State")
reoerder函数可将一个因子根据另一个变量进行排序
在aes内进行颜色映射设定,aes外重新设定颜色
data:image/s3,"s3://crabby-images/1209e/1209ecc1ccfbd298a679b06be26fc755bdb389c6" alt=""
b<-subset(climate,Source=="Berkeley"&Year>=1900)
b$pos<- b$Anomaly10y>=0
ggplot(b,aes(x=Year,y=Anomaly10y,fill=pos))+geom_bar(stat="identity",position = "identity")
创造一个新的函数来填充上色。
data:image/s3,"s3://crabby-images/41455/41455c34c854d988d485a91439fe06a4685cd0b4" alt=""
ggplot(b,aes(x=Year,y=Anomaly10y,fill=pos))+geom_bar(stat="identity",position = "identity",color="black",size=0.25)+scale_fill_manual(values=c("#669933","#FFCC66"),guide=FALSE)
改良版,将正负的颜色互换data:image/s3,"s3://crabby-images/d62d2/d62d2c08b904e6a1b40b9de82075ed93a6fb3dc4" alt=""
5.堆积条形图
ggplot(cabbage_exp,aes(x=Date,y=Weight,fill=Cultivar))+geom_bar(stat="identity")+guides(fill=guide_legend(reverse =TRUE ))
如果最后一段语句不加,堆积的上下相反
data:image/s3,"s3://crabby-images/b2cd2/b2cd2993adf3fba376e0aa235192fec705681f92" alt=""