华夫饼图:可视化展示利器(ggplot版本)
bigegpt 2024-09-27 00:36 6 浏览
写在前面
不知何时起,我总是喜欢在推文前面写上写在前面,可能是表达我的一种心境吧。在家里的日子在不断的测试和完善流程,每当我累了的时候,总想去gogle找一些新鲜东西,然后修改,适最后合自己的模子,变成对自己功能强大的样子,慢慢的这种方式变成了习惯。
华夫饼干图
在本文中,我将展示如何使用ggplot2绘图包在R中创建各种样式的“华夫饼”图。我定义了超过物种华夫饼图的元素,这些元素当然都会来自ggplot和相关的R包,然后修改了一个gihub上的函数,用于出图,因为后面微生物领域需要哟一些华夫饼图的需求,所以我这里做了一些尝试,希望可以有一些思考。
首先,我将为模拟数据创建一个数据框,初始化数据类型:
library(dplyr)
d <- data_frame(
date = as.Date(1:813, origin = "2018-01-01"),
year = format(date, "%Y"),
week = as.integer(format(date, "%W")) + 1, # Week starts at 1
day = factor(weekdays(date, TRUE),
levels = rev(c("周一","周二","周三","周四","周五","周六","周日"))),
hours = 0)
d
## # A tibble: 813 x 5
## date year week day hours
## <date> <chr> <dbl> <fct> <dbl>
## 1 2018-01-02 2018 2 周二 0
## 2 2018-01-03 2018 2 周三 0
## 3 2018-01-04 2018 2 周四 0
## 4 2018-01-05 2018 2 周五 0
## 5 2018-01-06 2018 2 周六 0
## 6 2018-01-07 2018 2 周日 0
## 7 2018-01-08 2018 3 周一 0
## 8 2018-01-09 2018 3 周二 0
## 9 2018-01-10 2018 3 周三 0
## 10 2018-01-11 2018 3 周四 0
## # ... with 803 more rows
然后模拟每个日期的工作时间。我将模拟周末和工作日分别工作的小时数,以使生成的数据更加真实,并模拟数据的缺失值(即没有工作的天数)。
set.seed(1)
# Simulate weekends
weekends <- dplyr::filter(d, grepl("S(at|un)", day))
# Hours worked are (might be) poisson distributed
weekends$hours <- rpois(nrow(weekends), lambda = 4)
# Simulate missing days with probability .7
weekends$na <- rbinom(nrow(weekends), 1, 0.7)
weekends$hours <- ifelse(weekends$na, NA, weekends$hours)
# Simulate weekdays
weekdays <- filter(d, !grepl("S(at|un)", day))
weekdays$hours <- rpois(nrow(weekdays), lambda = 8) # Greater lambda
weekdays$na <- rbinom(nrow(weekdays), 1, 0.1) # Smaller p(missing)
weekdays$hours <- ifelse(weekdays$na, NA, weekdays$hours)
# Concatenate weekends and weekdays and arrange by date
d <- bind_rows(weekends, weekdays) %>%
arrange(date) %>% # Arrange by date
select(-na) # Remove na column
d
## # A tibble: 813 x 5
## date year week day hours
## <date> <chr> <dbl> <fct> <int>
## 1 2018-01-02 2018 2 周二 NA
## 2 2018-01-03 2018 2 周三 7
## 3 2018-01-04 2018 2 周四 8
## 4 2018-01-05 2018 2 周五 NA
## 5 2018-01-06 2018 2 周六 NA
## 6 2018-01-07 2018 2 周日 12
## 7 2018-01-08 2018 3 周一 13
## 8 2018-01-09 2018 3 周二 9
## 9 2018-01-10 2018 3 周三 9
## 10 2018-01-11 2018 3 周四 4
## # ... with 803 more rows
华夫饼图功能函数
然后,我将创建一个绘制华夫饼图的函数。如果您具有类似的结构化数据,则可以复制粘贴该函数并将其用于数据)。
library(ggplot2)
library(viridis) # Color palette
library(ggthemes)
library(ggcor)
gh_waffle <- function(data, pal = "D", dir = -1,type = 21){
p <- ggplot(data, aes(x = week, y = day, fill = hours)) +
scale_fill_viridis(name="Hours",
option = pal, # Variable color palette
direction = dir, # Variable color direction
na.value = "grey93",
limits = c(0, max(data$hours))) +
# geom_tile(color = "white", size = 0.4) +
facet_wrap("year", ncol = 1) +
scale_x_continuous(
expand = c(0, 0),
breaks = seq(1, 52, length = 12),
labels = c("Jan", "Feb", "Mar", "Apr", "May", "Jun",
"Jul", "Aug", "Sep", "Oct", "Nov", "Dec")) +
theme_tufte(base_family = "Helvetica") +
theme(axis.title = element_blank(),
axis.ticks = element_blank(),
legend.position = "bottom",
legend.key.width = unit(1, "cm"),
strip.text = element_text(hjust = 0.01, face = "bold", size = 12))
#圆形
if(type == 21){p = p +geom_point(color = "white", size = 4,pch = 21) }
#方形
if(type == 22){p = p +geom_point(color = "white", size = 3,pch = 22)}
#菱方形
if(type == 23){p = p +geom_point(color = "white", size = 3,pch = 23) }
#上三角
if(type == 24){p = p +geom_point(color = "white", size = 3,pch = 24) }
#下三角
if(type == 25){p = p +geom_point(color = "white", size = 3,pch = 25) }
#星形状图
if(type == "star"){p = p +geom_star() }
#饼图
if(type == "pie2"){p = p + geom_pie2(size = 0.5) }
print(p)
}
使用华夫饼图功能
gh_waffle()接受三个参数,第一个data是具有以下列的数据框date:(类型:日期),year(数字或字符),week(数字),day(使日期从图的顶部到底部连续的有序因素)和hours(数字) 。第二个选项来pal指定由所使用的四个色调色板一个viridis,并且可以是“A”,“B”,“C”,或“D”。默认值为“ D”,这也是GitHub所使用的。最后一个选项dir指定色标的方向,可以是-1或1。GitHub的默认值为-1。
使用gh_waffle()默认设置,仅提供数据框d,将得到以下结果:
gh_waffle(d,pal = "D", dir = -1,type = 21)
方形
gh_waffle(d,pal = "D", dir = -1,type = 22)
菱形华夫饼图
gh_waffle(d,pal = "D", dir = -1,type = 23)
三角形华夫饼图
gh_waffle(d,pal = "D", dir = -1,type = 24)
gh_waffle(d,pal = "D", dir = -1,type = 25)
五角星的华夫饼图
厚哥的包,让我们可以使用五角星的华夫饼图
gh_waffle(d,pal = "D", dir = -1,type = "star")
饼图类型华夫饼图
gh_waffle(d,pal = "D", dir = -1,type = "pie2")
尝试不同配色方案
for (pal in c("A", "B", "C")) {
gh_waffle(d,pal, dir = -1,type = "star")
}
reference
https://vuorre.netlify.com/post/2016/03/24/github-style-waffle-plots-in-r/
相关推荐
- 有些人能留在你的心里,但不能留在你生活里。
-
有时候,你必须要明白,有些人能留在你的心里,但不能留在你生活里。Sometimes,youhavetorealize,Somepeoplecanstayinyourheart,...
- Python学不会来打我(34)python函数爬取百度图片_附源码
-
随着人工智能和大数据的发展,图像数据的获取变得越来越重要。作为Python初学者,掌握如何从网页中抓取图片并保存到本地是一项非常实用的技能。本文将手把手教你使用Python函数编写一个简单的百度图片...
- 软网推荐:图像变变变 一“软”见分晓
-
当我们仅需要改变一些图片的分辨率、裁减尺寸、添加水印、标注文本、更改图片颜色,或将一种图片转换为另一种格式时,总比较讨厌使用一些大型的图像处理软件,尤其是当尚未安装此类软件时,更是如此。实际上,只需一...
- 首款WP8.1图片搜索应用,搜照片得资料
-
首款WP8.1图片搜索应用,搜照片得资料出处:IT之家原创(天际)2014-11-1114:32:15评论WP之家报道,《反向图片搜索》(ReverseImageSearch)是Window...
- 盗墓笔记电视剧精美海报 盗墓笔记电视剧全集高清种子下载
-
出身“老九门”世家的吴邪,因身为考古学家的父母在某次保护国家文物行动时被国外盗墓团伙杀害,吴家为保护吴邪安全将他送去德国读书,因而吴邪对“考古”事业有着与生俱来的兴趣。在一次护宝过程中他偶然获得一张...
- 微软调整Win11 24H2装机策略:6月起36款预装应用改为完整版
-
IT之家7月16日消息,微软公司今天(7月16日)发布公告,表示自今年6月更新开始,已默认更新Windows1124H2和WindowsServer2025系统中预装...
- 谷歌手把手教你成为谣言终结者 | 域外
-
刺猬公社出品,必属原创,严禁转载。合作事宜,请联系微信号:yunlugongby贾宸琰编译、整理11月23日,由谷歌新闻实验室(GoogleNewsLab)联合Bellingcat、DigD...
- NAS 部署网盘资源搜索神器:全网资源一键搜,免费看剧听歌超爽!
-
还在为找不到想看的电影、电视剧、音乐而烦恼?还在各个网盘之间来回切换,浪费大量时间?今天就教你如何在NAS上部署aipan-netdisk-search,一款强大的网盘资源搜索神器,让你全网资源...
- 使用 Docker Compose 简化 INFINI Console 与 Easysearch 环境搭建
-
前言回顾在上一篇文章《搭建持久化的INFINIConsole与Easysearch容器环境》中,我们详细介绍了如何使用基础的dockerrun命令,手动启动和配置INFINICon...
- 为庆祝杜特尔特到访,这个国家宣布全国放假?
-
(观察者网讯)近日,一篇流传甚广的脸书推文称,为庆祝杜特尔特去年访问印度,印度宣布全国放假,并举办了街头集会以示欢迎。菲媒对此做出澄清,这则消息其实是“假新闻”。据《菲律宾世界日报》2日报道,该贴子...
- 一课译词:毛骨悚然(毛骨悚然的意思是?)
-
PhotobyMoosePhotosfromPexels“毛骨悚然”,汉语成语,意思是毛发竖起,脊梁骨发冷;形容恐惧惊骇的样子(withone'shairstandingonend...
- Bing Overtakes Google in China's PC Search Market, Fueled by AI and Microsoft Ecosystem
-
ScreenshotofBingChinahomepageTMTPOST--Inastunningturnintheglobalsearchenginerace,Mic...
- 找图不求人!6个以图搜图的识图网站推荐
-
【本文由小黑盒作者@crystalz于03月08日发布,转载请标明出处!】前言以图搜图,专业说法叫“反向图片搜索引擎”,是专门用来搜索相似图片、原始图片或图片来源的方法。常用来寻找现有图片的原始发布出...
- 浏览器功能和“油管”有什么关联?为什么要下载
-
现在有没有一款插件可以实现全部的功能,同时占用又小呢,主题主要是网站的一个外观,而且插件则主要是实现wordpress网站的一些功能,它不仅仅可以定制网站的外观,还可以实现很多插件的功能,搭载chro...
- 一周热门
- 最近发表
- 标签列表
-
- mybatiscollection (79)
- mqtt服务器 (88)
- keyerror (78)
- c#map (65)
- xftp6 (83)
- bt搜索 (75)
- c#var (76)
- xcode-select (66)
- mysql授权 (74)
- 下载测试 (70)
- linuxlink (65)
- pythonwget (67)
- androidinclude (65)
- libcrypto.so (74)
- linux安装minio (74)
- ubuntuunzip (67)
- vscode使用技巧 (83)
- secure-file-priv (67)
- vue阻止冒泡 (67)
- jquery跨域 (68)
- php写入文件 (73)
- kafkatools (66)
- mysql导出数据库 (66)
- jquery鼠标移入移出 (71)
- 取小数点后两位的函数 (73)