百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

R 数据可视化——ggplot 螺旋图

liuian 2025-05-25 14:04 9 浏览

前言

螺旋图是一种沿着阿基米德螺旋线绘制图形,从螺旋的中心向外螺旋式延伸。

螺旋图比较多变,可以使用条形、线或点几何对象。适用于显示较大的数据集或周期性数据。

示例

使用 ggplot2 绘制螺旋线,本质上还是要自己先对数据进行整理,如下图

group_by(bit_data, year, month) %>%
  summarise(value = mean(High), high = sd(High)) %>%
  mutate(
    x = month,
    # y 轴坐标随着月份的增加均匀升高,
    # 同时不同年份之间的高度首尾连续
    y = (year - 2015) * 11 + month - 1
  ) %>%
  ggplot(aes(x, y, group = year, colour = value)) +
  geom_line() +
  # coord_polar() +
  scale_colour_gradientn(colours = rainbow(3)) +
  scale_y_continuous("year", breaks = seq(0, 36, 12), labels = 2015:2018) +
  scale_x_continuous("month", breaks = 1:12, labels = 1:12)

4 条线分别代表 2015-2018 年份,x 轴代表的是月份,颜色表示的是比特币的价格。

我们需要以梯度的方式,各分组之间具有相同的斜率,且两条相邻的线条之间的前端与末端之间的高度是一样的

进行极坐标系变换之后,如下图

coord_polar() +
theme(
    panel.background = element_blank()
  )

将线条换成点图

如果要使用条形图,则会更麻烦一些,如果直接使用 geom_tile

看起来被割裂了一样,我们看看在笛卡尔坐标系下的样子

看起来我们应该将每个条形的右边坐标上提,也就是绘制底边平行的平行四边形

首先,我们需要计算出四边形的四个顶点,然后将右边的两个顶点向上平移,同时为条形图添加了随机的高度,用来模拟比特币价格在该月份中的波动范围

data <- group_by(bit_data, year, month) %>%
  summarise(value = mean(High)) %>%
  mutate(
    xmin = month,
    xmax = month + 1,
    ymin = (year - 2015) * 12 + month,
    ymax = ymin + runif(n(), min = 0.5, max = 1)
  ) %>%
  # 根据每行的四个坐标,构建成 4 行,代表 4 个点
  # 因为 geom_polygon 是逆时针连接起来的,所以点
  # 的顺序也要依次排列
  rowwise() %>%
  do(with(., tibble(
    year = year,
    month = month,
    value = value,
    x = c(xmin, xmax, xmax, xmin),
    y = c(ymin, ymin + 1, ymax + 1, ymax)
  )))

构建完数据之后,我们看看其在直角坐标系下的样子

ggplot(data, aes(x, y, group = paste(year, month))) +
  geom_polygon(fill = "green", colour = "black")

在这里,设置 group 参数非常重要。我们要每个月份作为一组,绘制一个平行四边形,所以需要根据年份与月份两列来进行分组

然后,将它旋起来

ggplot(data, aes(x, y, group = paste(year, month))) +
  geom_polygon(aes(fill = value), colour = "black") +
  coord_polar() +
  scale_x_continuous("month", breaks = seq(1.5, 12.5, 1), labels = month.name) +
  scale_fill_gradientn(values = seq(0,1,0.2), colours = c('cyan','blue','green','orange','red')) +
  ylim(c(-6, 60)) +
  theme(
    panel.background = element_blank(),
    axis.ticks = element_blank(),
    axis.title = element_blank(),
    axis.text.y = element_blank()
  )

换个配色

gcolors <- c("#8dd3c7", "#ffffb3", "#bebada", "#fb8072", "#80b1d3")

如果要绘制螺旋热图的话,可以将条形的高度设置为 12

# ymax = ymin + runif(n(), min = 3, max = 10)
ymax = ymin + 12
gcolors

也可以绘制螺旋面积图

首先构造数据

df <- tibble(
  date = seq(as.Date("2015-01-01"), as.Date("2019-12-31"), "days"),
  value = runif(length(date), min = 50, max = 300)
) %>%
  mutate(year = year(date), month = month(date), day = yday(date)) %>%
  # 去除闰年多出的一天
  filter(day != 366) %>%
  mutate(
    # 构造 y 轴梯度
    ymin = (year - 2015) * 364 + day, 
    ymax = ymin + value
  )

绘制图形

ggplot(df, aes(x = day, group = year)) +
  geom_ribbon(aes(ymin = ymin, ymax = ymax), fill = "orange") +
  geom_line(aes(y = ymin)) +
  geom_line(aes(y = ymax), colour = "grey40") +
  coord_polar(start = 1) +
  scale_x_continuous(
    breaks = c(1,31,59,90,120,151,181,212,243,273,304,334),
    labels = month.name
  ) +
  theme(
    panel.background = element_blank(),
    panel.grid.major.x = element_line(colour = "grey20", size = 0.25),
    axis.ticks = element_blank(),
    axis.title = element_blank(),
    axis.text.y = element_blank()
  )

如果想要添加渐变色,可以将 geom_ribbon 替换为 geom_linerange

gcolors = c("#8dd3c7", "#ffffb3", "#bebada", "#fb8072", "#80b1d3")

geom_linerange(aes(ymin = ymin, ymax = ymax, colour = value)) +
scale_colour_gradientn(values = seq(0,1,0.2), 
                         colours = gcolors)

这种颜色也挺好看的

gcolors = c('#7fc97f','#beaed4','#fdc086','#ffff99','#386cb0')

相关推荐

Chrome浏览器必学实用技巧-建议收藏

谷歌Chrome是目前最流行的桌面浏览器,本文分享了一些实用的使用技巧,希望能够对大家的工作和生活提供一些助力。贴士:不同版本的Chrome,其功能或菜单可能存在细微差异。本文使用的Chrome浏览器...

如何使用 Chrome 中的检查元素工具

如何在Chrome中使用Inspect元素启动检查元素工具的最简单方法是右键单击网页上的任何内容。然后,只需单击列表底部的“检查”选项。通常,Element是默认启动的。如果没有,那么您可以...

Chromedriver 在 Python 中查看源代码的方法

Python中可以属性来查看需要爬取的网站的源代码。对应具体的是:chrome.page_source需要注意的是首先需要导入包fromselenium.webdriverimportChro...

手机怎么查看HTML 文件

在手机端实现对HTML文件(包含本地文件和网页源代码)的查看,可借助多种途径和工具。以下为详细的操作步骤和实用的工具推荐:一、本地HTML文件的查看(一)利用浏览器打开定位文件:在手机的文件管...

防止学生查看答案,竟然让Chrome禁止查看源码功能

Chrome现在是很多人的主力浏览器,用户多了需求也会很多。Chrome每天都会收到很多意见和功能需求。然而有一个需求很奇怪,要求Chrome禁止查看网页源码的功能。这是怎么回事呢?1.问题背景我们都...

如何查看网页的HTML源代码?这里提供详细步骤

每个主要的互联网浏览器都允许用户查看任何网页的HTML(超文本标记语言)源代码。以下部分包含有关在每个主要浏览器中查看源代码的多种方法的信息。引言查看网页的源代码时,服务器处理的信息和代码不会出现。例...

如何在浏览器账中查看网页的HTML源代码?

浏览html网页,查看其源代码,可以帮助我们了解该版网页的信息以及架构,每个浏览器都是允许用户查看他们访问的任何网页的HTML源代码的。以下编程狮小师妹就介绍几个常见浏览器的查看网页HTML源代码...

python基础快速入门

Python是一种简单易学且功能强大的编程语言,适合初学者入门学习,不论是就业还是做副业赚钱或者是提高自己办公效率都是不错的选择。1.安装Python下载Python:前往Python官...

Python 如何创建一个 JSON 对象

我们可以使用下面的代码来在Python中创建一个JSON对象。importjsondata={}data['key']='value'json...

牛啊牛啊:C#/.NET一行代码把实体类类型转换为Json数据字符串

前言:刚好要做一个类似Swagger那种可以快速访问api接口和演示的功能,于是就把做的思路写到包里面去,给有需要的小伙伴提供学习和参考。首先,安装1.0.10以及以上版本的Wesky.Net.Op...

基于Jackson封装Json工具类:Java对象与JSON字符串的高效转换

在现代的Web开发和API设计中,JSON(JavaScriptObjectNotation)作为一种轻量级的数据交换格式被广泛使用。它易于人阅读和编写,同时也易于机器解析和生成。在Java生态系...

Python数据持久化:JSON

编程派微信号:codingpy上周更新的《ThinkPython2e》第14章讲述了几种数据持久化的方式,包括dbm、pickle等,但是考虑到篇幅和读者等因素,并没有将各种方式都列全。本文将介绍...

js中关于json语法和json遍历问题

什么是JSON?JSON英文全称JavaScriptObjectNotationJSON是一种轻量级的数据交换格式。JSON是独立的语言*JSON易于理解。json对象使用js语法,但...

Python 使用 JsonPath 完成接口自动化测试中参数关联和数据验证

背景:接口自动化测试实现简单、成本较低、收益较高,越来越受到企业重视RESTFul风格的API设计大行其道JSON成为主流的轻量级数据交换格式痛点接口关联接口关联也称为关联参数。在应用业务接口...

Spark读取kafka复杂嵌套json的最佳实践

随着互联网的更进一步发展,信息浏览、搜索以及电子商务、互联网旅游生活产品等将生活中的流通环节在线化,对于实时性的要求进一步提升,而信息的交互和沟通正在从点对点往信息链甚至信息网的方向发展,这样必然带来...