举个栗子~Tableau 技巧(244):用和弦图(Chord diagram)呈现数据关系

news2025/8/6 18:25:43

关于和弦图

和弦图(Chord diagram)常用来表示数据之间的相互关系。数据点沿着圆圈分布,通过点和点之间相互连接的弧线来呈现相互之间的关系。和弦图从视觉上来说比较美观,数据呈现又很直观,所以深受数据粉喜爱。

之前,我们分享过 🌰:轻松搞定 关系网 图表,如果数据粉希望换一种方式呈现数据关系,可以考虑和弦图哦~
关系和弦图的实现方法会相对复杂一些,因此我们用一份容易理解的电影角色关系数据(如下示例),来分享它的实现方法!
图片

图片

本期的栗子,一睹为快吧!

本期《举个栗子》,我们要给大家分享的 Tableau 技巧是:用和弦图(Chord diagram)呈现数据关系。

为方便学习,栗子使用自拟的“人物关系和弦图”数据源。掌握栗子方法后,数据粉可尝试使用自己的数据源。懒癌患者可通过以下链接获取栗子数据源:

https://www.dkmeco.com/cms/course/detail/645

D-栗子数据源

图片

▲ sheet 1

  • 角色 ID:用于识别角色的唯一 ID,同一人物 角色 ID 和关系人 ID 相同;

  • 关系人 ID:用于识别关系人的唯一 ID,同一人物 角色 ID 和关系人 ID 相同;

  • 主要关系类型:对角色和关系人的关系的离散分类;

  • 关系描述:对角色和关系人的关系的文字描述,缺失此字段不影响图形展示;

  • 连接:lonely moon 表和 repetition 表内连的字段,相同即可。

图片

sheet 2 ▲

  • R:范围从 0.01~1 共计 100 个数,以及单独的 2。此字段的目的为了在 Tableau 连接两个表,将 lonely moon 的数据重复 101 遍;

  • 连接:与 lonely moon 的连接相同,都为1,方便“内连接”。

Tips:所有的人物 ID 都需要有一行角色 ID,即使该人物 ID没有对应的关系人 ID,例如:孙光阳;虽然关系是相互的,但是在数据中,若已经有了金刚鼠->孙光阳的关系,即可不必补充孙光阳->金刚鼠的关系。

具体步骤如下:

连接数据源
打开 Tableau Desktop,连接栗子数据源,将两个表 “lonely moon” 和 “Repetition” 通过内联接在一起。
图片

图片

图片

创建参数

新建工作表,单击“数据”窗格右上角 ▼ 符号,在下拉菜单中选择:创建参数。
➤ 创建参数:distance,用于调整人物图和关系线之间的距离,如图设置。
图片

➤ 创建参数:突出角色,用于点击关系线时,突出显示线两端的头像使用,参数内需包含所有的角色,以及手动在“值列表”添加一个“全部”,如图设置。
图片

➤ 创建参数:突出关系人,用于点击关系线时,突出显示线两端的头像使用,参数内需包含所有的关系人,以及手动在“值列表”添加一个“全部”,如图设置。
图片

创建计算字段

新建工作表,单击“数据”窗格右上角 ▼ 符号,在下拉菜单中选择:创建计算字段。需要创建 14 个计算字段。
➤ 计算字段:各角色最小关系id,键入函数:

{ FIXED [角色id]:MIN([关系人id])},该字段用于限制只出现一个头像点 。

图片

➤ 计算字段:总人数,键入函数:

{fixed:COUNTD([角色id])},该字段用于三角函数使用。

图片

➤ 计算字段:标签,键入函数:
IF [R] = 2 then [角色] END,该字段用于显示头像的名称。
图片

➤ 计算字段:突出点,键入函数:
if ([突出关系人]=[角色] or [突出角色]=[角色]) and [R]=2
and [关系人id]=[各角色最小关系id] then ‘可突出’
ELSEIF [突出角色]=[角色] and [R]!=2 and [突出关系人]=[关系人] then ‘可突出’
else ‘不可突出’ end
该字段用于点击关系线时,确定哪些点应该突出显示。
图片

➤ 计算字段:关系人.x,键入函数:
COS([关系人id]/[总人数] * PI() * 2) //范围cos(2Π/n ~2Π) [-1,1)
图片

➤ 计算字段:关系人.y,键入函数:
sin([关系人id]/[总人数] * PI() * 2) //范围sin(2Π/n ~2Π) [-1,1)
图片

➤ 计算字段:角色.x,键入函数:
COS([角色id]/[总人数] * PI() * 2) //范围cos(2Π/n ~2Π) [-1,1)
图片

➤ 计算字段:角色.y,键入函数:
sin([角色id]/[总人数] * PI() * 2) //范围sin(2Π/n ~2Π) [-1,1)
图片

➤ 计算字段:余弦.x,键入函数:
COS((ACOS([角色.x])+ACOS([关系人.x]))/2)
图片

➤ 计算字段:正弦.y,键入函数:
SIN((ASIN([关系人.y])+ASIN([角色.y]))/2)
图片

➤ 计算字段:距离,键入函数:
SQRT(([角色.x] - [关系人.x])^2 + ([角色.y] - [关系人.y])^2)
图片

➤ 计算字段:x,键入函数:
IF [R] >= 0 AND [R] <= 1
THEN (( (1 - [R])^2 ) * [角色.x]) + (2 * (1 - [R]) * [R] * ( ((2 - [距离])/ 2) *[余弦.x] )) + ([R]^2 * [关系人.x]) END
注意:创建完成后,右键单击该字段,将其转化为:维度、再转化为:连续。
图片

➤ 计算字段:y,键入函数:
IF [R] >= 0 AND [R] <= 1
THEN (( (1 - [R])^2 ) * [角色.y]) + (2 * (1 - [R]) * [R] * ( ((2 - [距离])/ 2) * [正弦.y] ) ) + ([R]^2 * [关系人.y])
ELSEIF [R] = 2 and [关系人id]=[各角色最小关系id]
THEN [distance] * [角色.y] END
注意:创建完成后,右键单击该字段,将其转化为:维度、再转化为:连续。
图片

➤ 计算字段:x.shape,键入函数:
IF [R] = 2 and [关系人id]=[各角色最小关系id]
THEN [distance] * [角色.x] END
注意:创建完成后,右键单击该字段,将其转化为:维度、再转化为:连续。
图片

为便于数据管理,可将刚刚创建的这些计算字段,根据用途分别放在三个文件夹里。

图片

创建视图

首先,将计算字段“x”和“x.shape”拖放至列,将“y”拖放至行。再对“x”和“x.shape”做双轴和同步轴操作,并移除“全部”“标记”卡上的“度量名称”颜色胶囊。
图片

打开“x”“标记”卡,将其标记类型改为:线,并如下图将各个字段拖放至该“标记”卡中(注意:需要将字段“R”转化为维度、再转化为连续,然后再拖放到“路径”中)。
图片

单击“x”“标记”卡的工具提示,如下图设置:
图片

打开“x.shape”“标记”卡,并如下图将各个字段拖放至该“标记”卡中。
图片

按照 🌰 如何插入自定义形状 方法,将角色头像图片放入电脑中。
图片

单击“x.shape”“标记”卡的形状,为各个角色设置对应的头像。
图片

图片

设置好之后,可以根据需要调整一下大小。
图片

然后,将字段“突出点”拖放至“全部”“标记”卡的详细信息中,如下图。
图片

设置仪表板操作

新建仪表板,将刚刚创建的工作表拖放至右侧视图中。然后,单击顶部菜单栏“仪表板”,下拉菜单选择:操作,需要添加三个操作。
图片

弹窗中,需要以此选择,添加一个突出显示操作、两个参数操作。

图片

➤ 参数:传递需要突出的关系人,如下图设置。
图片

➤ 参数:传递需要突出的角色,如下图设置。
图片

➤ 突出显示动作:突出显示1,如下图设置。
图片

完成后,可以实现单击关系线,突出显示关系线和关系线两端的头像的功能,见下图。
图片

最后,再按需设置文字、线粗细、颜色、格式等等,就实现了我们想要的电影《独行月球》角色关系和弦图了。
图片

本期的 Tableau 技巧,你 Get 到了吗?
下一期,再见~
在这里插入图片描述

文章部分信息来源于网络,如有侵权请告知

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/15770.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux初阶】Linux调试器-gdb使用 | gdb的 l/b/info/d/r/n/s/bt/finish/p/(un)display/q

&#x1f31f;hello&#xff0c;各位读者大大们你们好呀&#x1f31f; &#x1f36d;&#x1f36d;系列专栏&#xff1a;【Linux初阶】 ✒️✒️本篇内容&#xff1a;gdb使用相关背景知识&#xff0c;gdb的使用&#xff08;打断点、查断点、消断点、调试运行、查看对应变量&…

【python拼图游戏】图片自选,来挑战一下自己的极限吧~

嗨害大家好鸭&#xff01;我是小熊猫❤ 拼图的画面多以自然风光、建筑物以及一些为人所熟识的图案的为题材。 城堡和山峦是两类传统的主题&#xff0c; 不过任何图画和影像都可以用做拼图的素材。 有一些公司还提供将私人摄影作品制成拼图的服务。 今天我小熊猫就给带来py…

FFmpeg5.1 解码rtsp 并用OpenCV 播放

RTSP 连接过程如下图 看下实际过程中FFmpeg 的日志情况&#xff1a; [tcp 0000014CC3256D40] No default whitelist set [tcp 0000014CC3256D40] Original list of addresses: [tcp 0000014CC3256D40] Address ::1 port 8554 [tcp 0000014CC3256D40] Address 127.0.0.1 po…

使用BP神经网络、RBF神经网络以及PSO优化的RBF神经网络对数据进行预测(Matlab代码实现)

&#x1f352;&#x1f352;&#x1f352;欢迎关注&#x1f308;&#x1f308;&#x1f308; &#x1f4dd;个人主页&#xff1a;我爱Matlab &#x1f44d;点赞➕评论➕收藏 养成习惯&#xff08;一键三连&#xff09;&#x1f33b;&#x1f33b;&#x1f33b; &#x1f34c;希…

Keysight是德科技E5061B网络分析仪-安泰测试

E5061B ENA系列网络分析仪从5Hz 至3GHz提供了广泛的频率范围。它不仅支持一般的射频应用(例如滤波器或放大器测量等)&#xff0c;还支持低频应用(例如直流至直流转换器环路增益测量)。因此&#xff0c;它是所有实验台上进行网络分析的最重要工具。 拥有E5061B&#xff0c;您就…

Selenium4 新特性

一、Selenium4 简介 Selenium是一个综合性项目,包含一系列的工具和库,支持Web浏览器的各种自动化操作: 软件测试爬虫领域RPA领域优点: 开源:https://github.com/SeleniumHQ兼容性: Chrome、FireFox、Edeg、IE、Opera、Safari支持多种编程语言:Java、Python、C#、Ruby、…

Charles抓包web、手机、小程序配置

一、下载地址 二、web抓包 Charles Web抓包&#xff0c;启动Charles会自动与浏览器设置成代理&#xff0c;不需要进行过多的设置。接下来就是通过浏览器发送网络请求&#xff0c;Charles就会直接抓取到这些信息和响应信息。 1、抓取HTTPS协议 Charles配置 点击顶部菜单栏【He…

双功能螯合剂p-NCS-Bz-DFO,1222468-90-7,p-SCN-Bn-Deferoxamine特点分析

●外观以及性质&#xff1a; p-SCN-Bn-Deferoxamine属于双功能螯合剂&#xff0c;西安凯新生物科技有限公司是各种修饰性PEG供应商&#xff0c;提供各种品质优良PEG衍生物&#xff0c;分子量从1000-40000不等&#xff0c;纯度≥95%&#xff0c;发货速度快。 ●中文名&#xff…

Web学习笔记-React

笔记内容转载自AcWing的Web应用课讲义&#xff0c;课程链接&#xff1a;AcWing Web应用课。 CONTENTS1. React配置环境2. ES6语法补充3. Components1. React配置环境 React官网&#xff1a;React。 React是一个声明式&#xff0c;高效且灵活的用于构建用户界面的JavaScript库…

凡事预则立,不预则缺货!2022年底了核芯物联蓝牙AOA定位基站GA25缺货!GA10缺货!GA60也缺货!

凡事预则立&#xff0c;不预则缺货&#xff01;2022年底了核芯物联蓝牙AOA定位基站GA25缺货&#xff01;GA10缺货&#xff01;GA60也缺货&#xff01; 核芯物联岳毅恒 ​ 深圳核芯物联科技有限公司 战略合作拓展总监 凡事预则立&#xff0c;不预则缺货&#xff01;202222年底…

brython | 初探鼠标事件-1:点击事件

各位前端大佬勿笑话&#xff0c;运维小弟献丑了。 前段时间看见大佬使用【文言文】写了一个连连看&#xff0c;于是我也想用【brython】也实现一个连连看。 于是乎&#xff0c;你们就看到这篇文章和这个项目了。 如果大佬们对brython不是特别了解的话&#xff0c;建议先查看之…

JVM分析工具

JVM在运行过程中&#xff0c;我们可以利用各种工具对JVM进行分析&#xff0c;这是性能调优的利器。可以通过各种工具了解在系统运行过程中&#xff0c;在JVM底层到底发生了什么。JVM分析工具一般分为两种&#xff0c;一种是命令行工具&#xff0c;一种是图形界面工具。 JVM分析…

卷积操作的不同类型

文章目录1. 一维卷积2. 二维卷积3. 三维卷积4. 扩张卷积5. 空洞卷积6. 分组卷积一般而言&#xff0c;一维卷积用于文本数据&#xff1b;二维卷积用于图像数据&#xff0c;对宽度和高度都进行卷积&#xff1b;三维卷积用于视频及3D图像处理领域&#xff0c;对立方体的三个面进行…

CS5269TypeC转HDMI2.0+VGA带PD100W快充拓展坞方案芯片完整设计资料(原理图+PCB文件)

CS5269TypeC转HDMI2.0VGA带PD100W快充方案芯片原理图&#xff1a; 用于US Type-C或DP1.4连接到HDMI2.0转换器。CS5269集成了DP1.4HDMI2.0的输出端和VGA输出接口。另外&#xff0c;两个CC控制器包括CC通信&#xff0c;以实现DP Alt模式和功率传输功能&#xff0c;一个用于上游类…

SD-WAN NFV uCPE VNF

NFV&#xff08;network function virtulization) NFV&#xff08;network function virtulization&#xff0c;网络功能虚拟化&#xff09;是指一种操作框架&#xff0c;目的是为了将部署在COTS硬件上的、在虚拟基础架构中的VNF软件设备编排和自动化起来&#xff0c;然后进行…

精耕丨“银发族”与“熬夜党”都在养生,大健康品牌怎样精耕消费者需求?

“被疫情偷走的这三年”里&#xff0c;健康成为所有人不得不面对的生活命题。 丁香医生《2022国民健康洞察报告》显示&#xff0c;2021年人们平均存在4.8个健康困扰&#xff0c;算得上“人均亚健康”&#xff0c;其中情绪、身材、皮肤焦虑位列TOP3。 人们对稳住健康的追求也一…

5G无线技术基础自学系列 | 物理共享信道分配

素材来源&#xff1a;《5G无线网络优化实践》 一边学习一边整理内容&#xff0c;并与大家分享&#xff0c;侵权即删&#xff0c;谢谢支持&#xff01; 附上汇总贴&#xff1a;5G无线技术基础自学系列 | 汇总_COCOgsta的博客-CSDN博客 在LTE协议中&#xff0c;DCI的位置和对应…

第一章《初学者问题大集合》第8节:Java程序初步释疑

当成功运行了第一个Java程序,很多读者都对之前的各项操作以及所写的这行代码有一些不清楚的地方,本节就来解答一下这些问题。其实,初学者的大部分疑问都集中体现在图1-41中。 图1-41 源文件名与类名称 1.类是个什么东西? 前文曾经让各位读者在写代码之前先创建一个“类”…

day065:IO流、字节流、字节流写数据

目录 一、IO流 1.IO流的目的 2.IO的表示 二、IO流的分类 1.按流向分 2.按数据类型分 三、字节流 1.字节流写数据 2.字节流的注意事项 3.字节流写数据的三种方式 4.字节流写数据的两个问题 &#xff08;1&#xff09;字节流写数据如何换行&#xff1f; &#xff08;…

腾讯云服务器部署vue前端项目(Ubuntu+vue+nginx+nodejs+npm)

一、安装nodejs和npm sudo apt-get nodejs sudo apt-get npm 但是在安装npm后&#xff0c;输入npm --version时&#xff0c;会报错 此时&#xff0c;需要升级nodejs的版本&#xff0c;执行下面的两条命令 wget -qO- https://deb.nodesource.com/setup_16.x | sudo -E bash - …