R 数据可视化 —— 饼图

前言

饼图,是将总体看作一个圆,按照各分类的占比情况将圆划分大小不同的扇形,以弧度的大小来表示某一分类的占比。

饼图可以让人快速的了解各分类的情况,但一般分类的数量不能太多,太多会导致圆被切割为很多块,不利于展示

在饼图中,通常会将占比最大的分类放置在最显眼的地方,即 12 点钟方向的右边,而第二大占比放置在 12 点钟方向的左边。其余的分类依据逆时针方向放置

示例

使用 ggplot2 绘制饼图,首先需要将所有数据绘制成一条柱状图,并通过分类变量填充不同的颜色

p <- group_by(mpg, class) %>%
  summarise(percent = n() / nrow(mpg)) %>%
  ggplot(aes(x = factor(1), y = percent, fill = class)) +
  geom_col(colour = "white")

然后根据 y 轴,转换为极坐标系

p + coord_polar(theta = "y")

添加百分比注释

p + 
  coord_polar(theta = "y", start = 1.65) +
  geom_text(aes(label = paste0(round(percent * 100, 2), "%")), 
            position = position_fill(vjust = 0.5)) +
  theme(
    panel.background = element_blank(),
    axis.title = element_blank(),
    axis.text = element_blank(),
    axis.ticks = element_blank()
  )

也可以使用 graphics 包的 pie 函数绘制饼图

df <- group_by(mpg, class) %>%
  summarise(percent = n() / nrow(mpg)) %>%
  arrange(desc(percent))

pie(df$percent)

将标签替换成我们的分类标签

pie(df$percent, labels = df$class)

通过设置更小的 edges 参数的值,能够让圆形变成多边形

pie(df$percent, labels = df$class, edges = 22)

使用 densityangle 绘制密度线及其角度

pie(df$percent, labels = df$class, edges = 22,
    density = 18, angle = c(20,90,30,100,120,180,45))

更换颜色

library(RColorBrewer)
my_color <- brewer.pal(7, "Set2") 

pie(df$percent, labels = df$class, col = my_color)

为每个标签添加占比

pie(df$percent, labels = with(df, paste0(class, "(", round(percent, 2) * 100, "%)")), 
    col = my_color)

饼图变形

甜甜圈图

甜甜圈图或者说圆环图,本质上只是将饼图的中心挖空。如

p <- group_by(mpg, class) %>%
  summarise(percent = n() / nrow(mpg)) %>%
  ggplot(aes(x = 1, y = sort(percent, decreasing = TRUE), fill = class)) +
  geom_col(colour = "white")

p + 
  coord_polar(theta = "y", start = 1.65) +
  geom_text(aes(label = paste0(round(percent * 100, 2), "%")), 
            position = position_fill(vjust = 0.5)) +
  xlim(c(-1, 2)) +
  theme(
    panel.background = element_blank(),
    axis.title = element_blank(),
    axis.text = element_blank(),
    axis.ticks = element_blank()
  )

不同于饼图聚焦于各扇形的面积,甜甜圈图则是着重于强调圆环的长度,同时空间利用率更高,我们可以将注释放置在圆环内

p <- group_by(mpg, class) %>%
  summarise(percent = n() / nrow(mpg)) %>%
  ggplot(aes(x = 2, y = sort(percent, decreasing = TRUE), fill = class)) +
  geom_col(colour = "white")

p + 
  coord_polar(theta = "y", start = 1.65) +
  geom_text(aes(x = 1, label = paste0(class, "(", round(percent * 100, 2), "%)")), 
            position = position_fill(vjust = 0.5), size = 3, hjust = 0.5) +
  xlim(c(-1, 3)) +
  theme(
    panel.background = element_blank(),
    axis.title = element_blank(),
    axis.text = element_blank(),
    axis.ticks = element_blank()
  )

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

名本无名

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值