导语

你有想过将智能家居和 Tableau 结合么?Tableau 爱好者 Ann Jackson 就在自己家中,尝试实现将智能家居系统与 Tableau 仪表板集成在一起。根据灯光颜色非常“酷炫的”展示仪表板中的数据信息。想知道她如何脑洞大开?一起来看看!

Ann Jackson 曾在 Twitter 上发布了一个视频,展示了如何将智能家居系统与 Tableau 仪表板集成在一起。视频的内容就是三个灯泡的灯光颜色会随着仪表板中 KPI 结果的改变而动态变化。

她将照明设备连接到 Tableau 仪表板的原因除了 “比较酷炫” 之外 —— 还有一些很实际的原因。使用类似灯光的东西能够轻松表示 KPI 或 BAN ( Big ass number ) 的状态,让用户迅速理解数据信息!

实现这种展现方式,需要哪些准备工作?

为了实现智能家居系统和 Tableau 之间的集成,AnnJackson使用了 Python 。因为已经有人开发了库并将它们发布到 GitHub 上共享,所以Python 非常适合这种情况。另外一个原因是 TabPy,它允许您连接到 Python 服务器并通过计算字段运行本地 Python 代码。这些计算字段将在 Tableau 工作表中作为表计算。一般来说,当您将 Tableau 与 Python 结合使用时,您会得到一个数字 / 字符串 / 布尔值。

当然,这不代表您不能拓展 TabPy 的功能,或者以其他方式来使用它。这正是这个项目的意义所在。因为这涉及到智能家居和她正在学习的Python,而 Tableau 是她的最爱。所以这个项目对 Ann Jackson 来说也是一个持续项目。

如果您想模仿 Ann 所做的事,那么您需要一些硬件设备。比如飞利浦 Hue 灯和配套的桥接器。理论上您可以使用其他智能家居部件。如果您不熟悉智能家居是什么 - 它基本上是通过桥接器向灯泡,给锁和恒温器等设备发出命令。它同时也是一种媒介,将您与智能家居系统(通常是移动应用程序)相连接,并将命令或程序转换为系统中的元素。具体到这个项目中,Ann 使用 Python 库与她的桥接器进行交互。她选用的库是 Phue,这是一个 Python 库,用于与 Hue API 的交互。

智能家居系统和 Tableau 集成步骤

1

下载并安装 Phue 到 TabPy

首先她下载并安装了 Phue 到 Tableau - Python - Server(又称为 TabPy)。这样就可以通过 Tableau 的 Python 脚本调用库。在安装过程中,还运行了一个简单的脚本将库连接到我的桥接器 – 这是这一切工作的必要步骤。您必须建立起传输控件和灯具之间的连接。

2

使用 Python 进行测试和验证

接下来的部分就是输入代码,使用 Python 进行测试和验证误差,以及体验 Tableau 的乐趣。以下是最终计算出的结果:

利润率 KPI - 这是我们都熟悉的指标。我已经完成了基本的利润率计算,并根据参数进行了计算。计算结果将是 0 或 25000 。数字 0 和 25000 对应于灯泡的颜色输入。 0 是红色, 25000 是绿色。

这里是纯 Python 的计算字段。在这种情况下,我实际上并没有使用 Python 来压缩任何东西并返回结果,所以您会注意到返回参数是一个虚拟数字 1 。

3

使用 SCRIPT_INT 函数

您将在 Tableau 编辑器中的计算字段描述中看到它 - 要使用 SCRIPT_INT(或任何 SCRIPT 函数),格式为:将代码放在引号中,任何输入或参数都使用 _arg1, _arg2, _argN 。这些参数用逗号隔开。在例子中有一个参数,[ Profit Ratio KPI ],它被分配给了一个代码。

代码基本步骤如下:

设置 [ Profit Ratio KPI ] 为 a

导入 phue 库,以便我们可以使用它

使用桥接器(我内部网络中服务器的 IP 地址)

将光的饱和度设置为 254 - 这是额外的代码,但这能确保光线具有全饱和度

将 light hue 设为 a 值

返回1 - 只是为了好玩!

在测试此代码时,打开 Jupyter notebook,输入相同代码以在 Tableau 之外的地方对其进行测试。在正常情况下,可以给 a 分配一个数,运行代码,并有灯光改变颜色。在 Tableau 中,则必须调用参数的第一个变量 “ [ 0 ] ” 。因此,为了分离出想要的结果,必须在一个变量列表中指定想要的元素。所以 Ann 的 KPI 结果实际上就像 Python 符号中的[ 25000 ],被称为 _arg1 [0](non-Python folk:Python 的变量从 0 开始)。

从字面上看,所有事情都是在设置和构建 Tableau 组件。构建 BAN 并添加参数以动态输入目标变量。在输入正确的代码后,其他所有内容都将连接并正常工作。以下是其中一张 BAN 工作表的样子:

计算字段未在视图中的任何其他位置使用。(如果您在默认的工具提示上悬停,结果会显示 “1”)。

一旦设置了可视化,只需要与仪表板交互此集成就开始生效。在 Ann 发布的视频中,这个交互速度并不快。这是有原因的 - 从 Tableau 开始接受计算参数,将其传送到 Python 服务器,然后等待结果返回,这里需要一段时间。

Ann 进行的尝试非常有借鉴意义,如果你也有相似的想法,不妨参考本文进行下实践,也许您也能制作出更 “酷炫” 的数据展现形式!这是一个非常简单的整合和演示,通过几行代码,数据驱动的表现就可以存在于物理世界中。这也是物联网的一种应用,如果你对物联网有着浓厚的兴趣,那还不快来参加本周四 Tableau 举办的网络分享会!

BI 趋势 #5 —— 查看和理解物联网

时间: 2018 年 3 月 29 日 周四下午 2:00 – 3:00

物联网 ( IoT) 的普及推动了我们所见到的连接设备数量的大幅增长,Gartner 预测到 2020 年,消费者可使用的物联网设备数量将增加一倍多,“ 在线物联网设备将达到 204 亿台 ”。即便有着如此高的增长量,物联网数据的用例和实现并没有按照预期的线路发展。

但我们看到的一个积极趋势是:在物联网设备中利用基于位置的数据,并从中获得一系列优势。通过了解物联网设备的位置数据,我们能更好地了解正在发生的事情,并预测将在特定位置发生的情况。在本次网络研讨会中,我们将分析此趋势,并探讨查看和理解物联网数据的最佳实践和建议。

报名方式 :

python硬件编程智能家居_利用 Python 的力量,实现 Tableau 与智能家居系统集成相关推荐

  1. python机器人编程与操作_机器人Python极客编程入门与实战 PDF 完整目录版

    给大家带来的一篇关于Python编程相关的电子书资源,介绍了关于机器人.Python.极客编程.入门.实战方面的内容,本书是由电子工业出版社出版,格式为PDF,资源大小25.8MB,Python极客团 ...

  2. python怎么做面板数据分析_利用python进行数据分析之准备(一)

    原标题:利用python进行数据分析之准备(一) 欢迎关注天善智能微信公众号,我们是专注于商业智能BI,大数据,数据分析领域的垂直社区. 对商业智能BI.大数据分析挖掘.机器学习,python,R等数 ...

  3. 利用python从网页查找数据_利用Python模拟淘宝的搜索过程并对数据进行可视化分析...

    数据挖掘入门与实战 公众号: datadw 本文讲述如何利用Python模拟淘宝的搜索过程并对搜索结果进行初步的数据可视化分析. 搜索过程的模拟:淘宝的搜索页面有两种形式, 一种形式是, 2019/2 ...

  4. python 翻译库本地库_利用python爬取并翻译GEO数据库

    原标题:利用python爬取并翻译GEO数据库 GEO数据库是NCBI创建并维护的基因表达数据库,始于2000年,收录了世界各国研究机构提交的高通量基因表达数据,现芯片集数据量高达12万以上.想要从这 ...

  5. python树莓派编程 沃尔弗拉姆_《 Python树莓派编程》——3.3 Python入门-阿里云开发者社区...

    本节书摘来自华章出版社<Python树莓派编程>一书中的第3章,第3.3节,作者:[美]沃尔弗拉姆·多纳特(Wolfram Donat)著韩德强 等译,更多章节内容可以访问云栖社区&quo ...

  6. python根据url下载数据_利用Python如何实现根据URL地址下载并保存文件至对应目录...

    利用Python如何实现根据URL地址下载并保存文件至对应目录 发布时间:2020-11-16 14:23:11 来源:亿速云 阅读:58 作者:Leah 这篇文章将为大家详细讲解有关利用Python ...

  7. python制作的网站例子_利用Python绘制Jazz网络图的例子

    最近在进行社交网络的学习,想利用Python来进行分析,但是网上关于这方面的资料好像很少,所以自己进行了一点研究,算是有一点点进步,现在将自己的成果发出来,希望这方面感兴趣的同学也可以快速入门.话不多 ...

  8. python处理水站的数据_利用Python进行数据分析(一):数据清洗与准备

    b站的小伙伴们大家吼~~ 在b站摸了快四年鱼的菜鸡也想开始做知识分享了,虽然说是分享其实根本目的也是为了督促自己好好学习把QAQ. 从今天开始,我将会在专栏分享我在学习<利用Python进行数据 ...

  9. python实现冒泡排序完整算法_利用python实现冒泡排序算法实例代码

    利用python实现冒泡排序算法实例代码 冒泡排序 冒泡排序(英语:Bubble Sort)是一种简单的排序算法.它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.遍历数 ...

  10. python怎么去掉视频字幕_利用Python实现字幕挂载(把字幕文件与视频合并)思路详解...

    其实超简单超简单!python好现成的库,一下子省略了好多步骤! 本文在Windows环境下!linux只是不需要手动输入imagicmagick的位置! 需要用到的环境 python(基本上只要不是 ...

最新文章

  1. matlab plot3d_号称轻量级MATLAB的数学工具—Maple 2019.2
  2. (C语言)一种简易记法:生成[a,b]范围内的随机整数
  3. 大学老师吐血自白:指导学生写论文真是太太太太太难了!
  4. 【小程序】汇编实现判断回文
  5. Linux服务器-使用mysql
  6. 画动态分析图的个人小技巧
  7. 那些年搞不懂的多线程、同步异步及阻塞和非阻塞(二)---概念区分
  8. bootstrap .navbar-header 控制button隐藏/显示
  9. 高精度——A+B Problem(洛谷 P1601)
  10. string 都不能作用于switch_这个东西看似细细的,作用大大滴!每个人的牙齿都不能没有它!...
  11. React16:Hooks总览,拥抱函数式 (这大概是最全的React Hooks吧)
  12. AndroidStudio_安卓原生开发_Android中调用摄像头拍照_并剪裁图片---Android原生开发工作笔记138
  13. 5G 时代,将边缘计算进行到底!
  14. DB与ES混合应用之数据实时同步
  15. 关于C中字符串的输入和输出使用的函数不同所造成的影响
  16. HHL算法第四弹(回顾伴随、正定算子、半正定算子、正规算子、酉矩阵、幺正矩阵、厄米矩阵,极式分解,奇异值分解)
  17. 惠普服务器硬盘指示灯不亮或显示蓝色
  18. 【计蒜客 - 蓝桥训练】蒜厂年会(循环数列的最大子段和)
  19. JS算法笔记---移除元素
  20. 从数据结构及汇编角度深入学习go语言

热门文章

  1. Microsoft Message Analyzer (微软消息分析器,“网络抓包工具 - Network Monitor”的替代品)官方正式版现已发布...
  2. Postmaster主循环的大致流程
  3. dede单独显示查到了多少条记录的方法
  4. 为什么不建议企业组织自行配置SD-WAN?—Vecloud微云
  5. linux关于禁用硬件xinput使用
  6. Windows 下使用 工具修改文件的 时间
  7. UNL/EVE关联putty和wireshark
  8. C#中的快捷键,可以更方便的编写代码
  9. python socketserver实现服务器端执行命令 上传文件 断点续传
  10. Windows socket c++ TCP UDP 简单客户端 vs2013