R语言--ggplot2包

由于python中matplotlib包的画图功能比较基本,不怎么炫酷,所以想用R中的ggplot2来作图。用mysql作为数据中介,可以让python和R共享数据,这样数据处理起来能发挥各自优势,同时保持数据一致,而用R来做图也就方便很多了。

原来在做数据可视化的时候用过ggplot2,不过没有系统学过,现在再学一遍。《ggplot2:数据分析与图形艺术》是一本全面的书,可以作为工具书。这次复习看的是知乎上的一个问题:

https://www.zhihu.com/question/24779017

上面的回答很精炼,谢谢所有答主。

--

首先是ggplot2的思想:

  • 作一张图就是将数据特点映射到点、线等几何对象的大小、颜色等属性上
  • 一张统计图还可能包含数据的统计变换(均值、方差等,stats),最后绘制在某个特定的坐标系(coord)中,还可能有分面(facet,将绘图窗口划分为若干子窗口)用来生成数据不同子集的图形
  • ggplot2的作图方式是按照图层作图,先设置一张“画布”,然后再向“画布”上添加一层一层的图层(会ps的同学会觉得很熟悉)

几个概念:

  • 几何对象(geom_):代表在图中实际看到的图形元素,如点、线、多边形等
  • 图形属性(aes):横纵坐标、点的大小、颜色,填充色等
  • 统计变换(stat_):对数据进行的某种汇总与变换等
  • 标度(scale):其作用是将数据的取值映射到图形空间,例如用颜色、大小或形状来表示不同的取值。展现标度的常见做法是绘制图例和坐标轴--他们实际上是从图形到数据的一个映射,使读者可以从图形中读取原始数据
  • 坐标系(coord):描述了数据时如何映射到图形所在的平面的,它同时提供了看图所需的坐标轴和网格线
  • 分面(facet):描述了如何将数据分解为各个子集,以及如何对子集作图并联合进行展示。

书上说的作图语法的局限性:

  • 对于感兴趣的问题,并不指出应该采用什么图形来进行展示,语法只能提供关于作图流程的说明,并不能告诉你作什么图合适
  • 语法并不规定图形的外观是怎样的,应该根据经验确定
  • 并没有交互式操作,ggplot2只能绘制静态图形(?)想绘制交互式图形需要看其他文献

一个小例子:

library(ggplot2)   #加载包

x <- rnorm(100,14,5) #生成100个均值为14,方差为5正态分布随机数

y <- x + rnorm(100,0,1
)
p <- ggplot(data = NULL) + aes(x = x,y = y) #创建“画布”

#下面是添加点,这里是添加几何对象点,color就是图形属性,+号就是添加一个图层

p <- p + geom_point(color = "darkred")

#在添加一个图层,添加注释

p <- p + annotate("text",x =13 , y = 20,parse = T,label = "x[1] == x[2]")

#展示图形

print(p)
posted @ 2016-03-01 20:10  司空格子Ored  阅读(1239)  评论(0编辑  收藏  举报