R语言ggplot在一张图里同时画散点图和折线图
- 前言
- 前处理
- 二维数据列表
- 一维数据列表绘图
前言 ggplot画出的一张图中通常只有一种类型,比如纯粹的散点图或折线图。如果将两种不同类型图画一张图,则没有办法添加图例。比如同时画散点图geom_point()和折线图geom_line(),而这种类型的图经常用于展示模型校准结果。
个人理解ggplot可以使用两种类型的数据,一种是面板数据(二维数据列表),就是一列x值,若干列变量值,可以将变量用视觉映射表示,比如大小/形状/颜色。
一种是融合后的数据(一维数据列表),一列x值,一列变量名称,一列y值。也可以将变量用视觉映射表示,比如大小/形状/颜色。
接下来将从这两种数据表分别画图
【ggplot|R语言ggplot在一张图里同时画散点图和折线图】面板数据
文章图片
一维数据列表
文章图片
前处理
library("readxl")#读取excel数据
library(reshape2)#转化两种数据列表
library(ggplot2)
getwd()#获取当前文件路径
setwd("C:/3 PROJECT/2021 缅甸")#设置路径
workbook="C:/3 PROJECT/2021 缅甸/出图.xlsx"#读取文件
data_level=read_xlsx(workbook,sheet="潮位")#读取数据
data_level1=data_level[c("TIME","C3","C3模拟")]#二维数据
levelC3=melt(data_level1,id="TIME")#一维数据 使用melt转化数据
二维数据列表 这个方法是知乎weiya提供的。具体我也没搞明白,但是能用。即使用geom分别画点和线,然后手动自定义离散的度量
链接: link
p1=ggplot(data_level1)+
geom_point(aes(x=TIME,y=C3, color = "#D1484F", shape = "A", linetype = "A"), size=2 )+
geom_line(aes(TIME,C3模拟, color = "#3398CC", shape = "B", linetype = "B"),size=1)+
scale_y_continuous('C3潮位(m)')+
labs(x = "时间",y='C3潮位(m)')+
theme_bw()+
theme(legend.title=element_blank(),legend.position = c(0.9, 0.1))+
scale_color_manual(name = "group",
values = c('#D1484F' = '#D1484F', "#3398CC" = '#3398CC'),
breaks = c("#D1484F", "#3398CC"),
labels = c('实测值', '模拟值')) +
scale_shape_manual(name = "group",
values = c("A" = 16, "B" = NA),
labels = c('实测值', '模拟值')) +
scale_linetype_manual(name = "group",
values = c("A" = 0, "B" = 1),
labels = c('实测值', '模拟值'))
p1
文章图片
一维数据列表绘图 将variable分别映射到填充颜色fill,颜色color,大小size,同时画点和线,通过调整度量达到同时绘图的目的。
p11=ggplot(levelC3,aes(x=TIME,y=value,fill=variable,color=variable,size=variable))+
geom_point(aes(shape=variable),color="#D1484F") +
scale_size_manual(values=c(3,1))+
scale_shape_manual(values=c(15,NA))+
geom_line(aes(linetype=variable), size=1,color = "#3398CC") +
scale_linetype_manual(values = c(0,1))+
scale_y_continuous('C3潮位(m)')+
labs(x = "时间")+
theme_bw()+
theme(legend.title=element_blank(),legend.position = c(0.9, 0.1))+
scale_x_datetime(date_labels = "%H:%M")
p11
文章图片
到此结束!
推荐阅读
- 数据获取|poi兴趣点数据获取
- 数据获取|【数据分享】全国分省、市、县、乡镇行政区划矢量图(专业版shp、小白版ppt)免费下载
- 避免数字化转型失败的3大破局思路和4点建议 | 亿信华辰推荐
- 机器学习|bagging && boosting && stacking 集成学习
- 数据分析|数据分析学习1——数据获取,单因子探索分析与可视化
- 人工智能|Numpy+Pandas+Matplotlib(Python数据分析三剑客详细入门教程)
- 可视化|Python直方图绘图(NumPy,Matplotlib,Pandas和Seaborn)
- R语言入门课|R语言导入数据文件(数据导入、加载、读取)、使用Hmisc包的spss.get函数导入SPSS中的por格式文件
- R语言入门课|R语言使用dbinom函数生成二项分布密度数据、使用plot函数可视化二项分布密度数据(Binomial Distribution)