data:image/s3,"s3://crabby-images/bb9d6/bb9d64665c0a35441cdb725384466b2f1ba0d31f" alt=""
data:image/s3,"s3://crabby-images/fbf1b/fbf1b11886f998b27cb16f7f6cf043b40a0d0d4a" alt=""
data:image/s3,"s3://crabby-images/f51ab/f51ab437e9b488f541a62ce51f420ea004009a74" alt=""
基础包作图函数
plot(iris[,1],iris[,3],col = iris[,5])
text(6.5,4, labels = 'hello') #text中6.5和4为hello的坐标
data:image/s3,"s3://crabby-images/9f7e1/9f7e13a73b2966caec678e1bcbe2ca6e0c3dbff5" alt=""
boxplot(iris[,1]~iris[,5])
data:image/s3,"s3://crabby-images/c8b11/c8b118558073d8b330faed1ee82a2be2dce71e42" alt=""
关闭画板
dev.off()
ggplot2绘图
1.入门级绘图模板
if(!require(ggplot2))install.packages('ggplot2')
library(ggplot2)
test = iris
#1.入门级绘图模板
ggplot(data = test)+
geom_point(mapping = aes(x = Sepal.Length,
y = Petal.Length))
data:image/s3,"s3://crabby-images/b6247/b6247400e0a135d759bd288156ba106bca0d797f" alt=""
2.映射-颜色、大小、透明度、形状
data:image/s3,"s3://crabby-images/1b51d/1b51d684fa4af9b4dbf11862a5a2042957f76e25" alt=""
ggplot(data = test)+
geom_point(mapping = aes(x = Sepal.Length,
y = Petal.Length,
color = Species))
data:image/s3,"s3://crabby-images/6d8ec/6d8ec1962efe415d2d484aa7573d0fd952458175" alt=""
data:image/s3,"s3://crabby-images/f6b2b/f6b2bf979a018e16e33caae04bf67ffb3bc06590" alt=""
3.分面
ggplot(data = test) +
geom_point(mapping = aes(x = Sepal.Length, y = Petal.Length)) +
facet_wrap(~ Species)
data:image/s3,"s3://crabby-images/b6079/b6079e26d41d9cb9fbe39bdf8572359bdc232157" alt=""
#双分面
test$Group = sample(letters[1:5],150,replace = T) #给数据test新加向量Group,Group为5个可重复字母,共150个
ggplot(data = test) +
geom_point(mapping = aes(x = Sepal.Length, y = Petal.Length)) +
facet_grid(Group ~ Species)
data:image/s3,"s3://crabby-images/038ab/038ab2ac16317092cb33da86475baf9ab0d71b7e" alt=""
练习走一波
# 示例数据:ggplot2中数据集mpg
View(mpg)
data:image/s3,"s3://crabby-images/746d7/746d7486bc65d79b936f0f294b8bf7bec3ae99e7" alt=""
# 1.分别以mpg的displ和hwy两列作为横纵坐标,画点图。
ggplot(data = mpg)+
geom_point(aes(x=displ,y=hwy))
#或者用下列代码
ggplot(data = mpg,aes(x=displ,y=hwy))+
geom_point()
data:image/s3,"s3://crabby-images/e19e7/e19e7e3cba990a961fac965d75bb57178448f0b6" alt=""
# 2.尝试修改颜色或大小,从mpg数据框中任选可以用来分类的列。
ggplot(data = mpg)+
geom_point(aes(x=displ,y=hwy,color=displ))
#或者用下列代码
ggplot(data = mpg,aes(x=displ,y=hwy,color=displ))+
geom_point()
data:image/s3,"s3://crabby-images/e9357/e935734032cce8553d03adcca10a475ebcb66f82" alt=""
# 3.根据class列来分面
ggplot(data = mpg)+
geom_point(aes(x=displ,y=hwy,color=displ))+
facet_wrap(~class)
#或者用下列代码
ggplot(data = mpg,aes(x=displ,y=hwy,color=displ))+
geom_point()+
facet_wrap(~class)
data:image/s3,"s3://crabby-images/3433c/3433c122d6d9fcf27f3355eb961087a4ef72d9ae" alt=""
# 4.根据drv和cyl两个变量来分面
ggplot(data = mpg)+
geom_point(aes(x=displ,y=hwy,color=displ))+
facet_grid(drv~cyl)
#或者用下列代码
ggplot(data = mpg,aes(x=displ,y=hwy,color=displ))+
geom_point()+
facet_grid(drv~cyl)
data:image/s3,"s3://crabby-images/d3678/d3678fdbcbb5764762a241485946f63b49418f06" alt=""
4.几何对象
data:image/s3,"s3://crabby-images/db77f/db77f7335c09252b7deceaf7e2ec29f9960502d6" alt=""
ggplot(data = test) +
geom_smooth(mapping = aes(x = Sepal.Length,
y = Petal.Length))
data:image/s3,"s3://crabby-images/ca8dc/ca8dc427cf616e7f92dd02836c6720ff6fbef1df" alt=""
ggplot(data = test) +
geom_smooth(mapping = aes(x = Sepal.Length,
y = Petal.Length,
group = Species))
data:image/s3,"s3://crabby-images/5eada/5eada7fd1d8bfb5543289361580a9a0164ad0c51" alt=""
ggplot(data = test) +
geom_smooth(mapping = aes(x = Sepal.Length,
y = Petal.Length,
color = Species))
data:image/s3,"s3://crabby-images/04976/049763cb03bfb7bfebf806004ea1a8f91be66cb1" alt=""
data:image/s3,"s3://crabby-images/68d55/68d559c71cae3235b13f6891ac9b31bec45a4bb1" alt=""
#局部映射
ggplot(data = test) +
geom_smooth(mapping = aes(x = Sepal.Length,
y = Petal.Length))+
geom_point(mapping = aes(x = Sepal.Length,
y = Petal.Length))
data:image/s3,"s3://crabby-images/217cb/217cb5502f3bcf4fe7d4b6e6e10b8fcf210c958c" alt=""
#全局映射
ggplot(data = test,mapping = aes(x = Sepal.Length, y = Petal.Length))+
geom_smooth()+
geom_point()
data:image/s3,"s3://crabby-images/92f5d/92f5d665a2cf078f3cec5b0e8ccd5c2b72d92c3c" alt=""
# 1.尝试写出下图的代码
# 数据是iris
# X轴是Species
# y轴是Sepal.Width
# 图是箱线图
ggplot(iris,aes(x=Species,y=Sepal.Width))+
geom_boxplot()
data:image/s3,"s3://crabby-images/ecf95/ecf95e74867cd62e71b8608bcf78a7fa46240f23" alt=""
# 2. 尝试在此图上叠加点图,
# 能发现什么问题?
ggplot(iris,aes(x=Species,y=Sepal.Width))+
geom_boxplot()+
geom_point()
data:image/s3,"s3://crabby-images/4ead1/4ead12ac811f8947fd7722e8c3b66728f5d0cbfa" alt=""
# 3.用下列代码作图,观察结果
ggplot(test,aes(x = Sepal.Length,y = Petal.Length,color = Species)) +
geom_point()+
geom_smooth(color = "black")
data:image/s3,"s3://crabby-images/65d81/65d81e14603cf56c4782747f52489ebd964ca501" alt=""
当局部映射和全局映射冲突,以局部映射为先。
5.统计变换
View(diamonds)
data:image/s3,"s3://crabby-images/21eaf/21eaffe8c647d6c7ccd01e510a5904daab9584a0" alt=""
data:image/s3,"s3://crabby-images/e8c87/e8c87b0628cdcd49f3c706a49601f3b72a5aece7" alt=""
ggplot(data = diamonds) +
geom_bar(mapping = aes(x = cut))
data:image/s3,"s3://crabby-images/2f4ff/2f4ff5a91317764cd9948c5592e76490a8fcfce9" alt=""
ggplot(data = diamonds) +
stat_count(mapping = aes(x = cut))
data:image/s3,"s3://crabby-images/25ebe/25ebed857217ddaa0c0a9cf9b55ba87c669e6095" alt=""
#统计变换使用场景
#5.1.不统计,数据直接做图
fre = as.data.frame(table(diamonds$cut))
fre
data:image/s3,"s3://crabby-images/8a2f0/8a2f061c0ecd54de2e8c016004892d1e675752f2" alt=""
#使用表中数据直接作图而不统计
ggplot(data = fre) +
geom_bar(mapping = aes(x = Var1, y = Freq), stat = "identity") #stat = "identity"设定为不统计
data:image/s3,"s3://crabby-images/21811/21811d9b58582d50d2d3525cbc6f03b496ca5c96" alt=""
#5.2count(计数)改为prop(百分比)
ggplot(data = diamonds) +
geom_bar(mapping = aes(x = cut, y = ..prop.., group = 1))
data:image/s3,"s3://crabby-images/2c5cd/2c5cdcb1e563dee819f0ef135abf0a1109c95de2" alt=""
6.位置调整
View(mpg)
data:image/s3,"s3://crabby-images/59805/59805802fcdeb995beaffc3d89d95f953a2a6c06" alt=""
ggplot(data = mpg,mapping = aes(x = class,
y = hwy,
group = class)) +
geom_boxplot()+
geom_point()
data:image/s3,"s3://crabby-images/5b6b7/5b6b7cccb8f9667effbbc511fbd48d8e3c515f18" alt=""
ggplot(data = mpg,mapping = aes(x = class,
y = hwy,
group = class)) +
geom_boxplot()+
geom_jitter()
data:image/s3,"s3://crabby-images/1a9ae/1a9ae9f7aa5bb8e48de96a851ae3210c73f59b39" alt=""
data:image/s3,"s3://crabby-images/def5a/def5af151842aa988fb026929b834d34cb6f261f" alt=""
# 6.2堆叠直方图
ggplot(data = diamonds) +
geom_bar(mapping = aes(x = cut,fill=clarity))
data:image/s3,"s3://crabby-images/30153/301537e7b00f6f5601a950ff04b454a2b0031597" alt=""
# 6.3 并列直方图
ggplot(data = diamonds) +
geom_bar(mapping = aes(x = cut, fill = clarity), position = "dodge")
data:image/s3,"s3://crabby-images/ad3fa/ad3fa9b076a16b14ff086906a1d9094933a3fd82" alt=""
7.坐标系
#翻转coord_flip()
ggplot(data = mpg, mapping = aes(x = class, y = hwy)) +
geom_boxplot() +
coord_flip()
data:image/s3,"s3://crabby-images/3571c/3571cbfa34895a8ff1d44a27c736fafeefb7c792" alt=""
#练习题走一波
ggplot(iris,aes(Species,Sepal.Width))+
geom_violin(aes(fill=Species))+
geom_boxplot()+
geom_jitter(aes(shape=Species))+
coord_flip()
data:image/s3,"s3://crabby-images/7ac2f/7ac2f252d1e2a89f4220f37ea4a8a1da0ce91bb3" alt=""
ggplot(iris,aes(Species,Sepal.Width))+
geom_violin(aes(fill=Species))+
geom_boxplot()+
geom_jitter(aes(shape=Species))+
coord_flip()+
theme_classic() # theme_classic()设置背景主题为白色不要网格
data:image/s3,"s3://crabby-images/c4696/c4696fe4cb8d21b3c8940694adc0b799792abcf2" alt=""
#极坐标系coord_polar()
bar <- ggplot(data = diamonds) +
geom_bar(
mapping = aes(x = cut, fill = cut),
show.legend = FALSE,
width = 1
) +
theme(aspect.ratio = 1) +
labs(x = NULL, y = NULL)
bar + coord_flip()
bar + coord_polar()
data:image/s3,"s3://crabby-images/57077/5707755fb642a20655f21f59d1fe80b7c086d80f" alt=""
①ggplot2绘制点图和线图
#加载R包和Boston数据
library(tidyverse)
library(MASS)
data(Boston)
head(Boston)
data:image/s3,"s3://crabby-images/8dc2a/8dc2a4e1c051359d1e2e71e1a998582192dc35c8" alt=""
#载入数据,aes映射数据到基本几何对象:点(x,y),size,shape,colour
p<-ggplot(data=Boston,aes(x=lstat,y=medv,colour=factor(rad)))
p
data:image/s3,"s3://crabby-images/f0de1/f0de1552f12b80434cdb3ec6eea202e93ef01c81" alt=""
绘制几何对象:点,线图
p+geom_point(aes(colour=factor(rad)),size=2.5)
#colour=factor(rad)按类别分颜色
data:image/s3,"s3://crabby-images/10200/10200480ea8d2bdb4510365b450adc463fa9cccd" alt=""
p+geom_point(colour="red",size=2.5)
data:image/s3,"s3://crabby-images/ef830/ef83007587394604cd4c31684f7a4925539d7488" alt=""
p+geom_point(aes(size=rad,shape=factor(rad)))
data:image/s3,"s3://crabby-images/026e5/026e5a7de6cbb019fc3f44636e8b2087f0521391" alt=""
Warning messages:
1: The shape palette can deal with a maximum of 6 discrete values
because more than 6 becomes difficult to discriminate; you
have 9. Consider specifying shapes manually if you must have
them.
2: Removed 173 rows containing missing values (geom_point).
解决上图问题用以下代码
p+geom_point(aes(size=rad,colour=factor(rad),shape=factor(rad)))+
scale_shape_manual(values=1:9)
data:image/s3,"s3://crabby-images/b536b/b536be56800ac8de8b6dbf156f30ea01fd225617" alt=""
p+geom_line(colour='red')
data:image/s3,"s3://crabby-images/f6f28/f6f281d916c155f492b9ebd85c72edd43946253a" alt=""
②ggplot2绘制直方图
#R内置数据集mpg
p2<-ggplot(mpg,aes(hwy))
data:image/s3,"s3://crabby-images/b2caf/b2caf0fc523f80bf1d2f121d6ac6602fecdfc2de" alt=""
p2+ geom_histogram(position ='identity', #position ='identity'两个直方图的位置重叠到一起
alpha=0.7,binwidth=2, #alpha=0.7填充颜色的透明度,binwidth=2直方图条形宽度
aes(y = ..density.., #y = ..density..y轴值取密度
fill =factor(year)))
data:image/s3,"s3://crabby-images/6abd1/6abd19f2ce68713bb7a1f52f5b4caea70a8cb5d7" alt=""
p2+ geom_histogram(position ='stack', #position ='stack'两个直方图的位置堆叠到一起
alpha=0.7,binwidth=2, #alpha=0.7填充颜色的透明度,binwidth=2直方图条形宽度
aes(y = ..density.., #y = ..density..y轴值取密度
fill =factor(year)))
data:image/s3,"s3://crabby-images/28d9b/28d9bd0fee8fa471f9482d2e7d8dc20f8a2b2327" alt=""
添加密度曲线
p2+ geom_histogram(position ='identity', #position ='identity'两个直方图的位置重叠到一起
alpha=0.7,binwidth=2, #alpha=0.7填充颜色的透明度,binwidth=2直方图条形宽度
aes(y = ..density.., #y = ..density..y轴值取密度
fill =factor(year)))+ #fill =factor(year)按照不同年份填充不同颜色
stat_density(geom ='line', position ='identity', #stat_density绘制密度曲线
aes(colour =factor(year)))
data:image/s3,"s3://crabby-images/25f76/25f7670a7d4a26c84f43a1b9b084d664a54d47cf" alt=""
将一个图分成两个图
p2+ geom_histogram(position ='identity', #position ='identity'两个直方图的位置重叠到一起
alpha=0.7,binwidth=2, #alpha=0.7填充颜色的透明度,binwidth=2直方图条形宽度
aes(y = ..density.., #y = ..density..y轴值取密度
fill =factor(year)))+ #fill =factor(year)按照不同年份填充不同颜色
stat_density(geom ='line', position ='identity', #stat_density绘制密度曲线
aes(colour =factor(year)))+
facet_grid(.~year) #将一个图分成两个图
data:image/s3,"s3://crabby-images/90450/90450606f02849aa254bcbe3e2c54105b4bdaee7" alt=""
网友评论