作者:丁点helper
来源:丁点帮你
上篇文章利用泰坦尼克号沉船事件中乘客的存活情况介绍了描述性数据分析,计算了不同舱位乘客的幸存率,今天我们来看看如何用图像来直观表达。
我们先来简单复习一下titanic.csv的内容。
# 导入数据 titanic <- read.csv("//Users//Desktop//titanic.csv",header = TRUE) names(titanic) # 查看titanic中的变量名 head(titanic) # 查看titanic前6行
上篇文章计算的不同舱位乘客的死亡与幸存人数如下:
table(titanic$survived,titanic$pclass) 1st 2nd 3rd died 123 158 528 survived 200 119 181
不同舱位生存率:
survpct=paste(round(tab1[2, ]/apply(tab1,2,sum)*100,2),"%",sep="") survpct [1] "61.92%" "42.96%" "25.53%"
如果我们想直观地描述不同舱位乘客的幸存率,可以用下面的做法:
绘制柱状图
barplot(table(titanic$survived,titanic$pclass))
barplot()是绘制柱状图的函数,该函数括号中的命令为绘图所需的数据,就是前面我们计算过的不同舱位死亡及幸存者人数。
柱状图的颜色也可调整,下面的代码中,col是更改柱状图颜色的命令:
barplot(table(titanic$survived,titanic$pclass), col=c("yellow","dark blue"))
每个舱位死亡与幸存人数柱子的排列方式也可调整,beside为改变柱状图排列方式的命令;beside=T意为两个柱子并排,beside=F意为两个柱子上下叠放。
barplot(table(titanic$survived,titanic$pclass), col=c("yellow","dark blue"), beside=T)
至此,我们已经可以将数字转变为直观的图像了,但是黄色和蓝色的柱子分别代表幸存者还是死亡者呢?此外,图像的标题等重要信息也未标示出来,图像的可读性还需要通过下面的步骤来提升:
设置图例、标题、坐标轴标签等
做法比较简单,在上面代码的基础上,增加一些命令即可:
barplot(table(titanic$survived,titanic$pclass), col=c("yellow","dark blue"), beside=T, legend=T, args.legend=list(x="topleft"), main="Survival (Pct) by Passenger Class", xlab="Class",ylab="Count", ylim=c(0,600))
legend为设置图例的命令;args.legend为设置图例位置的命令;
main为设置图标题的命令;
xlab、ylab分别为设置x轴和y轴名称的命令;
ylim为设置y轴范围的命令。
从这个图像可以清晰地看出,一等舱的幸存者人数为三个舱位中最多的,而三等舱的死亡者人数远高于其他两个舱位。但是这个图像还缺少一个信息,就是各舱位的存活率,我们可以在每个舱位的柱子上面标记一下:
text(c(2,5,8),c(250,250,570),survpct, cex=1.2)
text()为给图片中增加文字的函数。
其中前两个命令为文字的位置信息,第一个命令为文字设置x轴方向的位置信息,c(2,5,8)表示将文字分别放置在x取值为2,5,8处。
第二个命令为文字增加y轴方向的位置信息,c(250,250,570)表示将其分别放置在y取值为250,250,570处。
第三个命令为文字的具体内容,survpct是之前程序的运行结果,为一、二、三等舱乘客的幸存率。
第四个命令cex为文字字号,默认值为1,此处设置为1.2,意为比默认字号大20%。
以上代码默认标题、x轴、y轴的文字均为英文,但有时我们也需要将其设置为中文,此时只需在上面这段代码中增加一个『字体 (family)』命令:将图片中的文字设置成中文。
barplot(table(titanic$survived,titanic$pclass), col=c("red","blue"), beside=T, legend=T, args.legend=list(x="topleft"), main="不同舱位乘客幸存数(率)", xlab="舱位",ylab="人数",family = "SimHei", ylim=c(0,600))
family命令需要赋值字体的英文名称,本文将字体设置为"SimHei",即黑体。
此处还可设置其他字体,以下链接中总结了常见中文字体的英文名,大家可根据自己的需要选择。
部分字体中英文名称,资料来源于下面的链接
http://guangzheng.name/2017/12/18/%E5%A6%82%E4%BD%95%E8%B0%83%E6%95%B4R%E8%AF%AD%E8%A8%80%E7%BB%98%E5%9B%BE%E7%9A%84%E5%AD%97%E4%BD%93/
想从事业务型数据分析师,您可以点击>>>“数据分析师”了解课程详情;
想从事大数据分析师,您可以点击>>>“大数据就业”了解课程详情;
想成为人工智能工程师,您可以点击>>>“人工智能就业”了解课程详情;
想了解Python数据分析,您可以点击>>>“Python数据分析师”了解课程详情;
数据分析咨询请扫描二维码
在现代数据驱动的世界中,数据挖掘和数据分析已经成为了许多行业的重要工具。尽管这两个概念经常被人混淆,但它们各自有着独特 ...
2024-09-07作为数据分析领域的一个重要工具,SPSS 在统计分析中广泛应用。无论是学术研究、商业分析,还是医疗、金融领域的数据处理,SPS ...
2024-09-07作为数据分析领域的一个重要工具,SPSS 在统计分析中广泛应用。无论是学术研究、商业分析,还是医疗、金融领域的数据处理,SPS ...
2024-09-07作为一名数据分析从业者,我深知系统化的流程对于成功完成数据分析项目至关重要。尤其是对初学者而言,掌握正确的分析步骤不仅 ...
2024-09-07作为一名热爱数据分析的从业者,我时常回想起刚入行时的摸索历程。数据分析是一个既充满挑战又激动人心的领域,尤其对于初学者 ...
2024-09-07信息管理与信息系统专业的学生在就业市场上具有广阔的前景。随着信息技术的不断发展和数字化转型的加速,对于既懂技术又懂管理 ...
2024-09-06商务数据分析与应用专业的学生考取CDA(Certified Data Analyst)证书对于提升就业竞争力是有帮助的。CDA证书是一套科学化、专 ...
2024-09-06首先,在众多的职业认证中,CDA(Certified Digital Analyst)数字化人才认证逐渐成为统计学专业学生的首选。该认证不仅能够提 ...
2024-09-06统计学专业毕业生的主要就业流向有三大部分:政府部门(统计局等),银行、保险公司、证券公司等金融部门,市场调查公司、咨询 ...
2024-09-06统计学,作为一种基于数据分析的方法论科学,在当前信息化、数据化的社会中愈发重要。在各种行业中,无论是金融业、制造业、医 ...
2024-09-06第 1 章 引言 随着信息技术的迅猛发展,人工智能(Artificial Intelligence, AI)迅速成为全球科技创新的焦 ...
2024-09-06信息管理与信息系统专业作为现代信息化社会中的一门重要学科,其毕业生在市场中的就业情况备受关注。随着信息技术的快速发展, ...
2024-09-06在当前信息时代,数据的爆炸式增长已经成为不可忽视的事实。随着大数据、云计算和人工智能等技术的迅速发展,数据分析在各行各 ...
2024-09-06随着数据科学和机器学习技术在各行各业中的广泛应用,数据分析师这一职业逐渐成为推动经济和技术 ...
2024-09-06随着数字技术的迅猛发展,数字经济已成为推动全球经济增长的重要动力。各行各业正在加速数字化转型,涌现出大量与数字经济相关 ...
2024-09-06在当今数字化时代,拥有相应的专业证书不仅是求职竞争中的利器,更是个人职业发展的一大助力。CDA(Certified Digital Associa ...
2024-09-06随着科技的迅猛发展,数字经济已经逐渐成为各国经济增长的重要引擎,涉及的领域和行业瞬息万变。从传统 ...
2024-09-06在如今的数据驱动世界里,商业数据分析师的角色愈发重要。我常与新手分享这样一个故事:当我第一次作为数据分析师进入职场时, ...
2024-09-06在当今数字化时代,数据已成为推动企业发展的新动力。特别是在商务领域,数据分析的能力不仅影响着企业的决策,更关系到其竞争 ...
2024-09-06在当前数字化转型浪潮中,BI(商业智能)数据分析已成为推动企业决策和提升效率的重要手段。作为数据分析从业者,我常常通过BI ...
2024-09-06