全栈 - 15 实战 Diamonds数据集探索

这是全栈数据工程师养成攻略系列教程的第十五期:15 实战 Diamonds数据集探索。

我们已经掌握了ggplot2的基本语法,接下来以Diamonds数据集为例,结合多种图形进行实战和巩固。

查看数据

新建一个R脚本,加载ggplot2并查看diamonds数据集,diamonds数据框包含53940行,有carat、cut、color、clarity、depth、table、price、x、y、z共10列,对应每个钻石的一些参数值。

# 加载包和数据集
library(ggplot2)
library(gcookbook)
diamonds

因为数据记录太多不便于展示,所以不妨先截取原始数据的一个子集。使用sample()函数从总行数中随机采样出1000个数,然后作为行索引从原始数据框中截取出采样的行。

# 截取子集
set.seed(123)
# 从全部行中采样出1000行
diamonds <- diamonds[sample(nrow(diamonds), 1000),]

可以用summary()str()函数查看数据框的一些概要信息。前者根据每列的数据类型,如果为数值型则给出最大值、最小值、均值等统计值,如果为类别型则给出各个水平的频数;后者给出每列的数据类型以及一些样本值。

# 查看数据框的一些概要信息
summary(diamonds)
str(diamonds)

可以使用head()tail()函数查看数据框的前几行或最后几行。

# 查看数据框的前几行或最后几行
head(diamonds)
tail(diamonds)

价格和克拉

我们知道,钻石越大价格自然越贵,所以首先来看看价格和克拉之间存在怎样的关系。

# 价格和克拉的关系
ggplot(diamonds) + geom_point(aes(x=carat, y=price))
# 加入color和cut的影响
ggplot(diamonds) + geom_point(aes(x=carat, y=price, color=color, shape=cut))

价格分布

我们再来看看钻石的价格分布情况,由于价格为连续型变量,所以用直方图进行绘制。将price映射到x轴,ggplot2会自动划分若干个区间并统计每个价格区间内的记录数量,因此可以将直方图理解为x轴为连续变量的条形图。

# 价格分布
ggplot(diamonds) + geom_histogram(aes(x=price))
# 加入cut的影响
ggplot(diamonds) + geom_histogram(aes(x=price, fill=cut))
# 分组直方图
ggplot(diamonds) + geom_histogram(aes(x=price, fill=cut), position="dodge")
# 百分比直方图
ggplot(diamonds) + geom_histogram(aes(x=price, fill=cut), position="fill")

纯净度分布

钻石的纯净度clarity为类别型变量,所以使用条形图绘制其分布。将clarity映射到x轴即可,y轴为每个水平下的记录数量。

# 纯净度分布
ggplot(diamonds) + geom_bar(aes(x=clarity))
# 加入color的影响
ggplot(diamonds) + geom_bar(aes(x=clarity, fill=color))

价格概率分布

使用密度图即可展示连续型变量的概率分布,即某一价格钻石出现的概率。在密度图中,整个概率密度曲线下方区域的面积积分等于1。细心的话可以发现,当直方图的区间无穷小,即区间数量无穷大时,所得的轮廓形状和密度图是相同的。

# 价格的概率分布
ggplot(diamonds) + geom_density(aes(x=price))
# 加入cut的影响
ggplot(diamonds) + geom_density(aes(x=price, color=cut))
# 加入color的影响
ggplot(diamonds) + geom_density(aes(x=price, color=color))

不同切工下的价格分布

我们希望了解不同切工下,钻石价格的分布情况,可以使用箱线图实现。cut是一个类别值,映射到x轴;price是一个连续值,映射到y轴。箱线图的“箱”展示了分布的上分位数、平均值和下分位数,“线”展示了分布的最大值和最小值。

# 不同切工下价格的分布
ggplot(diamonds) + geom_boxplot(aes(x=cut, y=price))
# 加入color的影响
ggplot(diamonds) + geom_boxplot(aes(x=cut, y=price, fill=color))

坐标变换

ggplot2可以对坐标轴进行丰富的坐标轴变换,使得x轴变量和y轴变量之间的关系更直观。例如对以下散点图中的price取对数,只需要加上scale_y_log10()即可。

# 坐标变换
ggplot(diamonds) + geom_point(aes(x=carat, y=price, color=color, shape=cut)) + scale_y_log10()

标题和坐标轴标签

最后,让我们给画好的图加上标题和坐标轴标签,同样直接加上labs()即可,并使用theme()指定所用字体,使得中文能够正常显示。

# 加上标题和坐标轴标签
ggplot(diamonds) + geom_point(aes(x=carat, y=price, color=color, shape=cut)) + scale_y_log10() + labs(x='克拉', y='价格', title='克拉和价格之间的关系') + theme(text=element_text(family='Microsoft YaHei'))

使用theme()可以对绘图中的各处细节进行非常精细的控制和调整,对于任何不满意的地方都可以进行微调,详细使用方法可以参考?theme

视频链接:Diamonds数据集探索

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

推荐阅读更多精彩内容