博客:www.jiaopengzi.com

焦棚子的文章目录

请点击下载附件

一、效果

二、data

三、添加字段

注意红色框标注地方

四、code

# 下面用于创建数据帧并删除重复行的代码始终执行,并用作脚本报头:
# dataset <- data.frame(dim, wd, values)
# 在此处粘贴或键入脚本代码:

====================================================================================================

参考:https://stackoverflow.com/questions/48259930/how-to-create-a-stacked-waterfall-chart-in-r

译文:https://codeday.me/bug/20190319/786734.html

====================================================================================================

library("ggplot2")

library("dplyr") df <- dataset df.tmp <- df %>%

mutate(

dim = factor(dim,

levels = c("A", "B", "C", "D")),

wd = factor(wd,

levels = c("E", "W", "Q"))

) %>% arrange(dim, desc(wd)) %>%

mutate(end.Bar = cumsum(values),

start.Bar = c(0, head(end.Bar, -1))) %>%

rbind(

df %>%

group_by(wd) %>%

summarise(values = sum(values)) %>%

mutate(

dim = "Total",

wd = factor(wd,

levels = c("E", "W", "Q"))

) %>%

arrange(dim, desc(wd)) %>%

mutate(end.Bar = cumsum(values),

start.Bar = c(0, head(end.Bar, -1))) %>%

select(names(df),end.Bar,start.Bar)

) %>%

mutate(group.id = group_indices(., dim)) %>%

group_by(dim) %>%

mutate(total.by.x = sum(values)) %>%

select(dim, wd, group.id, start.Bar, values, end.Bar, total.by.x) ggplot(df.tmp, aes(x = group.id, fill = wd)) +

geom_rect(aes(x = group.id,

xmin = group.id - 0.25,

xmax = group.id + 0.25,

ymin = end.Bar,

ymax = start.Bar),

color="black",

alpha=0.95) +

geom_segment(aes(x=ifelse(group.id == last(group.id),

last(group.id),

group.id+0.25),

xend=ifelse(group.id == last(group.id),

last(group.id),

group.id+0.75),

y=ifelse(wd == "E",

end.Bar,

max(end.Bar)2),

yend=ifelse(wd == "E",

end.Bar,

max(end.Bar)
2)),

colour="black") +

geom_text(

mapping =

aes(

label = ifelse(values < 150,

"",

ifelse(nchar(values) == 3,

as.character(values),

sub("(.{1})(.)", "\1,\2",

as.character(values)

)

)

),

y = rowSums(cbind(start.Bar,values/2))

),

color = "white",

fontface = "bold"

) +

geom_text(

mapping =

aes(

label = ifelse(wd != "E",

"",

ifelse(nchar(total.by.x) == 3,

as.character(total.by.x),

sub("(.{1})(.
)", "\1,\2",

as.character(total.by.x)

)

)

),

y = end.Bar+200

),

color = "#213058",

fontface = "bold"

) +

分类颜色设置

scale_fill_manual(values=c('#ADB175','#8E599F','#213058')) +

Y轴设置

scale_y_continuous(

expand=c(0,0),

limits = c(0, 4000),

breaks = seq(0, 4000, 500),

labels = ifelse(nchar(seq(0, 4000, 500)) < 4,

as.character(seq(0, 4000, 500)),

sub("(.{1})(.*)", "\1,\2",

as.character(seq(0, 4000, 500))

)

)

) +

scale_x_continuous(

expand=c(0,0),

limits = c(min(df.tmp$group.id)-0.5,max(df.tmp$group.id)+0.5),

breaks = c(min(df.tmp$group.id)-0.5,

unique(df.tmp$group.id),

unique(df.tmp$group.id) + 0.5

),

labels =

c("",

as.character(unique(df.tmp$dim)),

rep(c(""), length(unique(df.tmp$dim)))

)

) +

theme(

text = element_text(size = 14, color = "#213058"),

axis.text = element_text(size = 10, color = "#213058", face = "bold"),

axis.text.y = element_text(margin = margin(r = 0.3, unit = "cm")),

axis.ticks.x =

element_line(color =

c("black",

rep(NA, length(unique(df.tmp$dim))),

rep("black", length(unique(df.tmp$dim))-1)

)

),

axis.line = element_line(colour = "#213058", size = 0.5),

axis.ticks.length = unit(.15, "cm"),

axis.title.x = element_blank(),

axis.title.y = element_blank(),

panel.background = element_blank(),

plot.margin = unit(c(1, 1, 1, 1), "lines"),

legend.text = element_text(size = 10,

color = "#213058",

face = "bold",

margin = margin(l = 0.25, unit = "cm")

),

legend.title = element_blank()

)

注意:

1、R视觉对象,发布需要pro才行;

2、data的形式和X、Y轴的设置;

3、对R要有所了解。

by焦棚子

焦棚子的文章目录

120_PowerBI堆积瀑布图_R脚本Visual的更多相关文章

  1. 教你用Python创建瀑布图

    介绍 对于绘制某些类型的数据来说,瀑布图是一种十分有用的工具.不足为奇的是,我们可以使用Pandas和matplotlib创建一个可重复的瀑布图. 在往下进行之前,我想先告诉大家我指代的是哪种类型的图 ...

  2. 第四篇:R语言数据可视化之折线图、堆积图、堆积面积图

    折线图简介 折线图通常用来对两个连续变量的依存关系进行可视化,其中横轴很多时候是时间轴. 但横轴也不一定是连续型变量,可以是有序的离散型变量. 绘制基本折线图 本例选用如下测试数据集: 绘制方法是首先 ...

  3. 看懂 Fiddler 的瀑布图

    最近准备给组内的新同学们分享下 Fiddler 这枚神器,可以讲的地方太多,我打算把一节课讲不完的内容写在博客上,大家可以随便看看.今天先介绍下 Fiddler 的瀑布图. 每个网络请求都会经历域名解 ...

  4. Excel催化剂图表系列之品味IBCS瀑布图观察企业利润构成

    IBCS图表,每个细节都值得反复琢磨参悟,此篇给大家送上详尽的瀑布图方式下的利润数据观察.请不要拿Excel2016版提供的瀑布图与IBCS版的瀑布图作对比,那完全不是一个级别的,可以类比为拿一辆经济 ...

  5. maftools | 从头开始绘制发表级oncoplot(瀑布图)

    本文首发于微信公众号 **“ 生信补给站 ”** ,期待您的关注!!! 原文链接:https://mp.weixin.qq.com/s/G-0PtaoO6bYuhx_D_Rlrlw 对于组学数据的分析 ...

  6. Tableau绘制漏斗图、甘特图、瀑布图、镶边面积图、阴影坡度图

    Tableau绘制漏斗图.甘特图.瀑布图.镶边面积图.阴影坡度图 本文首发于博客冰山一树Sankey,去博客浏览效果更好.直接右上角搜索该标题即可 一. 漏斗图 数据源 1.1 分色直条漏斗图 (1) ...

  7. Unity 烘焙材质到单一贴图的脚本

    原地址:http://www.cocoachina.com/gamedev/gameengine/2011/0406/2756.html 这个脚本由 CocoaChina 版主 “四角钱” 分享,可以 ...

  8. Mac生成APP图标和启动图的脚本

    概述 之前用的一个批量导出APP图标和启动图的软件,今天发现收费了,于是自己造了个简单的轮子. 实现 Mac上的sips命令,可以很方便的帮助用户修改图片尺寸 Xcode里面的APP启动图资源包含两部 ...

  9. WPF数据可视化-瀑布图

    实现方式一: 将数据(Point[])根据索引沿X轴使用虚拟画布进行绘制,每个数据绘制大小为1px * 1px:最终绘制出的宽度等于数据的总长度.标记并存储当前绘制的图为PreviousBitmap; ...

随机推荐

  1. Flutter入门教程(四)第一个flutter项目解析

    一.创建一个Flutter工程 1.1 命令行创建 首先我们找一个空目录用来专门存放flutter项目,然后在路径中直接输入cmd: 使用 flutter create <projectname ...

  2. css 垂直居中方法汇总

    查看原文可以有更好的排版效果哦 前言 居中是平时工作中的最常见的一种需求,各种图片居中或者各种弹窗,水平居中还好,特别是垂直居中,很多初学者表示太难写了,现在列举一些常用的方法. 实战 这里只讲述cs ...

  3. php弹窗后跳入另一个页面

    之前写项目时,在跳转页面前加入一个弹窗,发现弹窗没有弹出来就直接跳转了,之前使用的header跳转发现不行,换成location.href也不行,后来再location.href前加入一个parent ...

  4. 自己给idea下载Scala插件

    场景:有时候在idea上直接下载的scala可能因为太新所以有bug,需要手动下载插件 经验:自己下载完之后发现比较老的版本idea根本不让你装,只能装一些跟idea上推荐的scala相近的版本,感觉 ...

  5. hibernate数据源

      Hibernate的描述文件可以是一个properties属性文件,也可以是一个xml文件.下面讲一下Hibernate.cfg.xml的配置.配置格式如下:1. 配置数据源 在Hibernate ...

  6. 写入MySQL中文乱码问题

    相信使用数据库进行存储的大家都遇到过中文乱码问题,如何彻底解决?我百度了很多资料与博客,想把自己的经历总结起来给大家参考一下,接下来我先罗列一下大部分修改乱码问题的方法: 1.   修改MySQL数据 ...

  7. 面试官:Zookeeper集群怎么搭建?

    哈喽!大家好,我是小奇,一位不靠谱的程序员 小奇打算以轻松幽默的对话方式来分享一些技术,如果你觉得通过小奇的文章学到了东西,那就给小奇一个赞吧 文章持续更新 一.前言 作为一名Java拧螺丝选手,不必 ...

  8. php代码审计之——phpstorm动态调试

    xdebug调试 调试环境部署 xdebug的版本需要与PHP版本相对于,所以不要轻易改变PHP环境版本. 0 配置php解析器 1 下载对应版本的xdebug xdebug官网下载地址:https: ...

  9. 猿人学python爬虫第一题

    打开网站.F12,开启devtools.发现有段代码阻止了我们调试 好的.接下来有几种解决方法 1- 绕过阻止调试方法 方法1(推荐) 鼠标放在debugger该行,左边数字行号那一列.右键选择不在永 ...

  10. win11拖动窗口造成崩溃的问题

    问题描述 拖动窗口,随机概率出现 屏幕闪烁 屏幕黑屏 屏幕瞬间分屏 解决方法 windowes11贴吧大神给的方案 1,按下 win键+R 输入 regedit 进入注册表,进入以下路径:计算机\HK ...