码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 161_可视化_Power BI 复刻 GitHub 贡献热力图


    161_可视化_Power BI 复刻 GitHub 贡献热力图

    一、背景

    在 GitHub 上,有用户的贡献度的热力图如下:

    161-1

    Power BI 公共 web 效果:https://demo.jiaopengzi.com/pbi/161-full.html

    我们使用 Power BI 来复刻一下,如下:

    161-8

    二、实现过程

    1、依赖

    • 上述热力图是基于日期维度的,所以日期表是必备的,且需要按照我们设计的日期表才能实现(参见:https://jiaopengzi.com/2635.html);可见在我们的 Power BI 项目中日期表的重要性。
    • 三方视觉对象 HTML Content

    161-3

    2、DAX

    实现热力图的度量值就三个,如下图。

    161-4

    Ⅰ、SVG_heat_map_type

    控制热力按照自然年显示,还是按照累计年显示。

    SVG_heat_map_type = SELECTEDVALUE('热力图'[id], 0)

    Ⅱ、SVG_measure

    业务指标度量值,在使用当前模板的时候需要把自己业务的度量值按照如下方式写入。

    SVG_measure = [0001_销售金额]

    Ⅲ、SVG_html

    实现可视化的核心度量值,使用 DAX 构造 SVG 。

    只需要设置如下参数即可。

    • id:请勿修改。
    • left:区间左边界,不包含。
    • right:区间右边界,包含。
    • display:最终显示的文本。
    • color:热力图图例每个格子的颜色。

    如上,除了 id 不能更改以外,其他都可以按照自己的需求修改。

    建议只需要修改 left、right、display 三个字段即可,颜色就用当前的默认颜色。

    SVG_title:图表标题,如果不需要标题则留空。

    161-5

    SVG_html =
    /*业务设置-开始++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
    VAR SVG_legend_text_table =
    DATATABLE (
    "id", INTEGER,"left", INTEGER,"right", INTEGER,"display", STRING,"color", STRING,
    {
    { 5, 0, 0, "0", "#ebedf0" },
    { 4, 0, 10000, "(0,10000]", "#9be9a8" },
    { 3, 10000, 50000, "(10000,50000]", "#40c463" },
    { 2, 50000, 100000, "(50000,100000]", "#30a14e" },
    { 1, 100000, 99999999, ">100000", "#216e39" }
    }
    )
    VAR SVG_title = "日维度销售金额热力图" //图表标题,如不需标题留空 "" 。历史 | 目标 | 预测差异分析
    /*业务设置-结束++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
    折叠

    剩余DAX 过长,请在:https://jiaopengzi.com/2828.html 查看。

    161-6

    当然我们也用 Power BI 三方视觉来做一个对比,根据需要选择使用。

    161-7

    三、总结

    1、在前面之前的文章(https://jiaopengzi.com/2796.html)我们已经使用 DAX + SVG 来实现一些商业图表了。

    2、在 Power BI 中是 SVG 不足之处在于图表本身的交互,但更多商业图表其实出现在最终报告中,也可以忽略这一点。

    3、日期表的原始设计很重要。

    附件下载

    https://jiaopengzi.com/2828.html

    视频课

    https://jiaopengzi.com/all-course

    by 焦棚子

  • 相关阅读:
    ffplay源码分析:音频重采样
    最新版GNS3安装详解,小白也可以独立完成哦!!
    QT两个类之间使用信号槽
    动手学强化学习(一)
    使用 Dockerfile 构建生产环境镜像
    基于STM32设计的便携式心电信号监测系统
    打印 Logger 日志时,需不需要再封装一下工具类?
    花998购买的拍摄技巧和7天起号培训文档,学了一周的总结。
    谁懂,java后端面试多次惨败并发的苦!幸好有阿里首发并发编程学习文档,系统全面还便于上手!
    misc学习(2)
  • 原文地址:https://www.cnblogs.com/jiaopengzi/p/16497492.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号