本文介绍: 主要涉及到对图的优化,使用ggchart工具包。

主要涉及到对图的优化,使用ggchart工具包

ggchart 链接:https://thomas-neitmann.github.io/ggcharts/index.html

step1: 安装工具包

install.packages("ggcharts")
install.packages("tidytext")

step2: 导入工具包

library(dplyr)
library(ggplot2)
library(ggcharts)
library(tidytext)

step3:使用数据

data("biomedicalrevenue")

step4: 绘图

plot <- biomedicalrevenue %>%
  filter(year %in% c(2012, 2015, 2018)) %>%
  group_by(year) %>%
  top_n(10, revenue) %>%
  ungroup() %>%
  mutate(company = tidytext::reorder_within(company, revenue, year)) %>%
  ggplot(aes(company, revenue)) +
  geom_col() +
  coord_flip() +
  tidytext::scale_x_reordered() +
  facet_wrap(vars(year), scales = "free_y")
  1. biomedicalrevenue 是一个数据框,其中包含了生物医药公司的营收信息。

  2. %>% 是管道操作符,用于将前一个步骤的结果传递给下一个步骤。

  3. filter(year %in% c(2012, 2015, 2018)) 用于筛选出包含在2012年、2015年和2018年的数据。

  4. group_by(year) 将数据按照年份进行分组。

  5. top_n(10, revenue) 选取每个年份中营收前10的公司。

  6. ungroup() 取消分组,确保后续的操作不受之前的分组影响。

  7. mutate(company = tidytext::reorder_within(company, revenue, year)) 重新排序公司,以确保每个年份中的公司按照营收从高到低排列。

  8. ggplot(aes(company, revenue)) 创建一个 ggplot 对象,设置 X 轴为公司名称,Y 轴为营收。

  9. geom_col() 添加堆积柱状图层。

  10. coord_flip() 将坐标轴翻转,使得柱状图变为横向。

  11. tidytext::scale_x_reordered() 根据重新排序的结果调整 X 轴的顺序。

  12. facet_wrap(vars(year), scales = "free_y") 按照年份进行分面,每个年份的柱状图分别显示,Y 轴的刻度独立。

整体来说,这段代码使用 ggplot2 包创建了一个生物医药公司营收的横向堆积柱状图,展示了2012年、2015年和2018年每年的前10位公司。

在这里插入图片描述

step5: 优化 v2

plot <- biomedicalrevenue %>%
  filter(year %in% c(2012, 2015, 2018)) %>%
  bar_chart(x = company, y = revenue, facet = year, top_n = 10)
  • 使用 bar_chart 绘制柱状图

在这里插入图片描述

原文地址:https://blog.csdn.net/weixin_45492560/article/details/135720783

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_59538.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注