R绘图基础指南 | 2.折线图

line.jpg

2.折线图

导入的时候很多图挂了,有需要的麻烦大家移步原文:https://mp.weixin.qq.com/s/AGZJtQkB-JvfBsX8XNDDpA

这个系列是关于R中基础图形和进阶图形的绘制。视频课程会陆续更新到我的B站【木舟笔记】,希望大家多多支持!

折线图通常用来对两个连续变量的相互依存关系进行可视化,其中,x轴对应于自变量,y轴对应于因变量。折线图的x轴通常对应的是连续型变量或者有序离散型变量。

2.1 绘制简单折线图

library(ggplot2)
ggplot(BOD, aes(x = Time, y = demand)) + geom_line()
plot of chunk unnamed-chunk-1
BOD
##   Time demand
## 1    1    8.3
## 2    2   10.3
## 3    3   19.0
## 4    4   16.0
## 5    5   15.6
## 6    7   19.8
BOD1 <- BOD  # Make a copy of the data
BOD1$Time <- factor(BOD1$Time) #转为因子型变量
ggplot(BOD1, aes(x = Time, y = demand, group = 1)) + geom_line()
plot of chunk unnamed-chunk-1

数据集BOD中没有对应于Time=6的数据点,因此Time被转化为因子型变量时,它并没有6这个水平。

可以运行ylim()设定y轴范围或者运行含一个参数的expand_limit()扩展y轴的范围。

# 以下结果都是相同的
ggplot(BOD, aes(x = Time, y = demand)) + geom_line() + ylim(0, max(BOD$demand))
ggplot(BOD, aes(x = Time, y = demand)) + geom_line() + expand_limits(y = 0)
plot of chunk unnamed-chunk-1

2.2 向折线图添加数据表记

ggplot(BOD, aes(x = Time, y = demand)) + geom_line() + geom_point()
plot of chunk unnamed-chunk-2
library(gcookbook) 
# wordlpop 对应的采集时间间隔不是常数。时间越近的采集频率越高。
ggplot(worldpop, aes(x = Year, y = Population)) + geom_line() + geom_point()

[图片上传失败...(image-352239-1626921661081)]

# 当y轴取对数时也一样
ggplot(worldpop, aes(x = Year, y = Population)) + geom_line() + geom_point() +     scale_y_log10()

[图片上传失败...(image-e761e1-1626921661081)]

2.3 绘制多重折线图

# 载入plyr,便于使用ddply() 创建样本数据集library(plyr)# 汇总ToothGrowth 数据集tg <- ddply(ToothGrowth, c("supp", "dose"), summarise, length=mean(len))# 将 supp 映射给 colourggplot(tg, aes(x=dose, y=length, colour=supp)) + geom_line()

[图片上传失败...(image-4287b7-1626921661081)]

# 将 supp 映射给 线型 linetypeggplot(tg, aes(x=dose, y=length, linetype=supp)) + geom_line()

[图片上传失败...(image-5bd46d-1626921661081)]

# ggplot(tg, aes(x=factor(dose), y=length, colour=supp, group=supp)) + geom_line()

[图片上传失败...(image-1edf2c-1626921661081)]

# 不能缺失group=supp语句,否则ggplot()会不知如何将数据组合在一起,从而报错ggplot(tg, aes(x=factor(dose), y=length, colour=supp)) + geom_line()
plot of chunk unnamed-chunk-3
# 分组不正确也有可能变成锯齿状ggplot(tg, aes(x=dose, y=length)) + geom_line()
plot of chunk unnamed-chunk-3
ggplot(tg, aes(x=dose, y=length, shape=supp)) + geom_line() +    geom_point(size=4)           # 更大的点
plot of chunk unnamed-chunk-3
ggplot(tg, aes(x=dose, y=length, fill=supp)) + geom_line() +    geom_point(size=4, shape=21) #使用有填充色的点

[图片上传失败...(image-bada48-1626921661081)]

# 数据标记相互重叠,需要相应的移动标记点以及连接线。ggplot(tg, aes(x=dose, y=length, shape=supp)) +   geom_line(position=position_dodge(0.2)) +#将连接线左右移动0.2      geom_point(position=position_dodge(0.2), size=4)  # 将点的位置左右移动0.2

[图片上传失败...(image-f2442c-1626921661081)]

2.4 修改线条样式

通过设置线型(linetype)、线宽(size) 和颜色(colour)参数可以分别修改折现的线型、线宽和颜色。

ggplot(BOD, aes(x = Time, y = demand)) +   geom_line(linetype = "dashed", size = 1,  colour = "blue")

[图片上传失败...(image-6a763f-1626921661081)]

library(plyr)tg <- ddply(ToothGrowth, c("supp", "dose"), summarise, length = mean(len))ggplot(tg, aes(x = dose, y = length, colour = supp)) +   geom_line() +   scale_colour_brewer(palette = "Set1"))

[图片上传失败...(image-72b077-1626921661081)]

# 在aes()函数外部设定参数则会对所有折线图有效ggplot(tg, aes(x = dose, y = length, group = supp)) +   geom_line(colour = "darkgreen", size = 1.5)

[图片上传失败...(image-a90ba9-1626921661081)]

# supp被映射给了颜色,所以自动作为分组变量ggplot(tg, aes(x = dose, y = length, colour = supp)) +   geom_line(linetype = "dashed") +       geom_point(shape = 22, size = 3, fill = "white")

[图片上传失败...(image-e9465c-1626921661081)]

2.5 修改数据标记样式

# geom_point()设置点大小、颜色、填充ggplot(BOD,aes(x = Time,y = demand)) +   geom_line() +   geom_point(size = 4,shape = 22,colour = "darkred",fill = "pink")

[图片上传失败...(image-2ae81a-1626921661081)]

ggplot(BOD, aes(x = Time, y = demand)) +   geom_line() +   geom_point(size = 4,shape = 21, fill = "white")

[图片上传失败...(image-31291f-1626921661081)]

pd <- position_dodge(0.2)ggplot(tg, aes(x = dose, y = length, fill = supp)) +   geom_line(position = pd) +       geom_point(shape = 21, size = 3, position = pd) +   scale_fill_manual(values = c("black","white"))

[图片上传失败...(image-b96f6b-1626921661081)]

2.6 绘制面积图

运行 geom_area() 函数即可绘制面积图

# 将sunspot.year数据集转化为数据框,便于本例使用sunspotyear <- data.frame(Year = as.numeric(time(sunspot.year)), Sunspots = as.numeric(sunspot.year))ggplot(sunspotyear, aes(x = Year, y = Sunspots)) + geom_area()

[图片上传失败...(image-405c6d-1626921661081)]

# 颜色、透明度设置ggplot(sunspotyear, aes(x = Year, y = Sunspots)) +   geom_area(colour = "black",fill = "blue", alpha = 0.2)

[图片上传失败...(image-c4615e-1626921661081)]

# 去掉底部横线 不设定colour,使用geom_line()绘制轨迹ggplot(sunspotyear, aes(x = Year, y = Sunspots)) +   geom_area(fill = "blue",alpha = 0.2) +   geom_line()

[图片上传失败...(image-aaa612-1626921661081)]

2.7 绘制堆积面积图

library(gcookbook) ggplot(uspopage, aes(x = Year, y = Thousands, fill = AgeGroup)) + geom_area()

[图片上传失败...(image-f3b0a5-1626921661081)]

head(uspopage)
> head(uspopage)  Year AgeGroup Thousands1 1900       <5      91812 1900     5-14     169663 1900    15-24     149514 1900    25-34     121615 1900    35-44      92736 1900    45-54      6437
# 通过设定breaks翻转堆积顺序# 透明度、颜色、大小设置ggplot(uspopage, aes(x = Year, y = Thousands, fill = AgeGroup)) +   geom_area(colour = "black", size = 0.2, alpha = 0.4) +   scale_fill_brewer(palette = "Blues", breaks = rev(levels(uspopage$AgeGroup)))

[图片上传失败...(image-ba486-1626921661081)]

# 设定order = desc(AgeGroup) 可以对堆积顺序进行反转library(plyr)  ggplot(uspopage, aes(x = Year, y = Thousands, fill = AgeGroup, order = desc(AgeGroup))) +       geom_area(colour = "black", size = 0.2, alpha = 0.4) +   scale_fill_brewer(palette = "Blues")

[图片上传失败...(image-20f3e9-1626921661081)]

# 去掉框线ggplot(uspopage, aes(x = Year, y = Thousands, fill = AgeGroup, order = desc(AgeGroup))) +       geom_area(colour = NA, alpha = 0.4) +   scale_fill_brewer(palette = "Blues") +       geom_line(position = "stack", size = 0.2)

[图片上传失败...(image-a74f41-1626921661081)]

2.8 绘制百分比面积堆积图

# 先计算百分比uspopage_prop <- ddply(uspopage, "Year", transform, Percent = Thousands/sum(Thousands) * 100)ggplot(uspopage_prop, aes(x = Year, y = Percent, fill = AgeGroup)) +   geom_area(colour = "black", size = 0.2, alpha = 0.4) +   scale_fill_brewer(palette = "Blues", breaks = rev(levels(uspopage$AgeGroup)))

[图片上传失败...(image-36f399-1626921661081)]

head(uspopage)
> head(uspopage)  Year AgeGroup Thousands1 1900       <5      91812 1900     5-14     169663 1900    15-24     149514 1900    25-34     121615 1900    35-44      92736 1900    45-54      6437
uspopage_prop <- ddply(uspopage, "Year", transform, Percent = Thousands/sum(Thousands) * 100)

2.9 添加置信域

运行 geom_ribbon()分别映射一个变量给 yminymax

climate数据集中的Anomaly10y变量表示了各年温度相对于1950-1980平均水平变异的10年移动平均。Unc10y表示其95%置信区间。

library(gcookbook) # 抓取 climate 数据的一个子集clim <- subset(climate, Source == "Berkeley", select = c("Year", "Anomaly10y",     "Unc10y"))head(clim)
> head(clim)  Year Anomaly10y Unc10y1 1800     -0.435  0.5052 1801     -0.453  0.4933 1802     -0.460  0.4864 1803     -0.493  0.4895 1804     -0.536  0.4836 1805     -0.541  0.475
# 将置信域绘制为阴影# 注意一下图层的顺序ggplot(clim, aes(x = Year, y = Anomaly10y)) +   geom_ribbon(aes(ymin = Anomaly10y - Unc10y, ymax = Anomaly10y + Unc10y), alpha = 0.2) +   geom_line()

[图片上传失败...(image-b192c0-1626921661081)]

# 使用虚线表示置信域的上下边界ggplot(clim, aes(x = Year, y = Anomaly10y)) +   geom_line(aes(y = Anomaly10y -Unc10y), colour = "grey50", linetype = "dotted") +   geom_line(aes(y = Anomaly10y +Unc10y), colour = "grey50", linetype = "dotted") +   geom_line()

[图片上传失败...(image-73e4cf-1626921661081)]

参考书籍

  • R Graphics Cookbook, 2nd edition.
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351