通过选择散点图上的点来更新虚线表

2024-01-05

我正在制作仪表板。这是我的代码:

# IMPORT SECTION
import dash
import dash_table
import dash_core_components as dcc
import dash_html_components as html
import dash_bootstrap_components as dbc
from dash.dependencies import Input, Output
import plotly.graph_objs as go
import numpy as np
import pandas as pd
from math import ceil
from matplotlib.cm import Set3


# INPUT DATA
n = 7
d_min = 0.2
d_max = 0.8
d_step = 0.1
N_min = 2000
N_max = 8000
N_step = 1000
D = 40
h = 20
dataframe_file = 'data.xlsx'


# COLOR AND FONT DEFINITION
grey = '#e0e1f5'
black = '#212121'
scatter_colors = ['#' + ''.join(['{:02x}'.format(int(255*Set3(i)[j])) for j in range(3)]) for i in range(n)]
fontsize = 18
fontfamily = 'Arial, sans-serif'


# READ CSV DATA
df = pd.read_excel(dataframe_file)


# CREATE DATA FOR DASH DATATABLE
df_scatter_colors = ceil(len(df) / len(scatter_colors)) * scatter_colors
df_scatter_colors = df_scatter_colors[:len(df)]
df.insert(loc = 0, column = 'COLOR', value = df_scatter_colors)

headers = [{"name": i, "id": i} for i in df.columns]

table = df.to_dict('records')

table_colors = [{'if': {'row_index': i, 'column_id': 'COLOR'},
                 'background-color': df.iloc[i]['COLOR'],
                 'color': df.iloc[i]['COLOR']} for i in range(df.shape[0])]


# CREATE DATA AND LAYOUT FOR THE SCATTERPLOT
x_jitter = 0.05 * N_step * np.random.randn(len(df))
y_jitter = 0.05 * d_step * 1000 * np.random.randn(len(df))
data = [go.Scatter(x = df['NUMBER'] + x_jitter,
                   y = df['DIAMETER'] + y_jitter,
                   text = df['PRODUCT'],
                   mode = 'markers',
                   hoverinfo = 'skip',
                   showlegend = False,
                   marker_color = 'rgba(0, 0, 0, 0)',
                   marker = {'size': 25,
                             'line': {'color': df['COLOR'],
                                      'width': 8}})]

layout = go.Layout(plot_bgcolor = black,
                   hovermode = 'x unified',
                   uirevision = 'value')

figure = go.Figure(data = data, layout = layout)


# DASHBOARD LAYOUT
app = dash.Dash(external_stylesheets = [dbc.themes.BOOTSTRAP])

app.layout = html.Div(id = 'general_div',
                      children = [html.Div(id = 'first_row',
                                           children = [dcc.Graph(id = 'main_graph',
                                                                 figure = figure,
                                                                 style = {'height': 800,
                                                                          'width': 1400})],

                                           className = 'row'),

                                  html.Div(id = 'second_row',
                                           children = [dash_table.DataTable(id = 'main_table',
                                                                            columns = headers,
                                                                            data = table,
                                                                            style_data_conditional = table_colors,
                                                                            style_table = {'margin-left': '3vw',
                                                                                           'margin-top': '3vw'},
                                                                            style_cell = {'font-family': fontfamily,
                                                                                          'fontSize': fontsize},
                                                                            style_header = {'backgroundColor': 'rgb(230, 230, 230)',
                                                                                            'fontWeight': 'bold'})],

                                           className = 'row')])


# CALLBACK DEFINITION
@app.callback(Output('main_table', 'style_data_conditional'),
              [Input('main_graph', 'selectedData'),
               Input('main_table', 'style_data_conditional')])
def display_selected_data(selectedData, style_data_conditional):
    # what to do here and how to run this callback?
    return style_data_conditional


if __name__ == "__main__":
    app.run_server()

仪表板中显示散点图(dcc.Graph)和一个表(dash_table.DataTable)。散点图的每个点对应于表的特定行,我从 Excel 文件中读取这些数据。
Excel文件中的数据格式如下:

PRODUCT CODE    NUMBER  DIAMETER
AAAAA   1412    8000    0.049
BBBBB   1418    3900    0.08
CCCCC   1420    7600    0.06
DDDDD   1426    8500    0.049
EEEEE   1430    3900    0.08
FFFFF   1442    3900    0.08
GGGGG   1490    8500    0.049
HHHHH   1504    9000    0.18
IIIII   1514    5500    0.224
JJJJJ   1584    7600    0.06
KKKKK   1606    8500    0.049
LLLLL   1618    7600    0.06
MMMMM   1638    7600    0.06
NNNNN   1640    7600    0.06
OOOOO   1666    3900    0.08
PPPPP   1670    8000    0.049
QQQQQ   1672    8000    0.049
RRRRR   1674    7600    0.06
SSSSS   1700    7100    0.071
TTTTT   1704    8500    0.049
UUUUU   1712    7600    0.06
VVVVV   1718    7600    0.06
WWWWW   1722    8000    0.065

我想实现这个功能:当用户选择散点图中的某个点时,代码会突出显示表中的相应行(例如,将这些行中单元格的背景颜色更改为'pink',除了'COLOR'列,保持其颜色)。

检查了这些来源:

  1. 破折号-数据表-个人-突出显示-使用-样式-数据-条件-工作-不寻常 https://stackoverflow.com/questions/60125805/dash-datatable-individual-highlight-using-style-data-conditionals-works-unusual
  2. 破折号数据表样式数据条件行副 https://community.plotly.com/t/dash-datatable-style-data-conditional-row-vice/21587
  3. 交互式绘图 https://dash-docs.herokuapp.com/interactive-graphing

我尝试绘制这样的回调,但没有成功:

@app.callback(Output('selected_data', 'children'),
              [Input('main_graph', 'selectedData'),
               Input('main_table', 'style_data_conditional')])
def display_selected_data(selectedData, style_data_conditional):
    selected_points = []
    for point in selectedData['points']:
        selected_points.append(point['marker.line.color'])
    selected = [{'if': {'filter': '{COLOR} eq ' + f'"{color}"',
                        'column_id': 'PRODUCT'},
                 'backgroundColor': 'pink'} for color in selected_points]
    style_data_conditional.extend(selected)

    return style_data_conditional

提前致谢。

版本信息

Python                       3.7.0
dash                         1.12.0
dash-bootstrap-components    0.10.1
dash-core-components         1.10.0
dash-html-components         1.0.3
matplotlib                   3.0.2
numpy                        1.15.4
plotly                       4.7.0

我设法解决了这个问题selectedData作为输入main_graph和加工main_table's style_data_conditional作为函数的输出update_table_style.
在这里,我用深灰色对奇数行进行着色,以提高表格的可见性,然后通过样式条件设置所选行的背景颜色。最后,我根据每行的颜色更改第一列的背景(每行第一列上报告的颜色)。

Code:

# IMPORT SECTION
import dash
import dash_table
import dash_core_components as dcc
import dash_html_components as html
import dash_bootstrap_components as dbc
from dash.dependencies import Input, Output
import plotly.graph_objs as go
import numpy as np
import pandas as pd
from math import ceil
from matplotlib.cm import Set3


# INPUT DATA
n = 7
d_min = 0.2
d_max = 0.8
d_step = 0.1
N_min = 2000
N_max = 8000
N_step = 1000
D = 40
h = 20
dataframe_file = 'data.xlsx'


# COLOR AND FONT DEFINITION
grey = '#e0e1f5'
black = '#212121'
scatter_colors = ['#' + ''.join(['{:02x}'.format(int(255*Set3(i)[j])) for j in range(3)]) for i in range(n)]
fontsize = 18
fontfamily = 'Arial, sans-serif'


# READ CSV DATA
df = pd.read_excel(dataframe_file)


# CREATE DATA FOR DASH DATATABLE
df_scatter_colors = ceil(len(df) / len(scatter_colors)) * scatter_colors
df_scatter_colors = df_scatter_colors[:len(df)]
df.insert(loc = 0, column = 'COLOR', value = df_scatter_colors)

headers = [{"name": i, "id": i} for i in df.columns]

table = df.to_dict('records')


# CREATE DATA AND LAYOUT FOR THE SCATTERPLOT
x_jitter = 0.05 * N_step * np.random.randn(len(df))
y_jitter = 0.05 * d_step * 1000 * np.random.randn(len(df))
data = [go.Scatter(x = df['NUMBER'] + x_jitter,
                   y = df['DIAMETER'] + y_jitter,
                   text = df['PRODUCT'],
                   mode = 'markers',
                   hoverinfo = 'skip',
                   showlegend = False,
                   marker_color = 'rgba(0, 0, 0, 0)',
                   marker = {'size': 25,
                             'line': {'color': df['COLOR'],
                                      'width': 8}})]

layout = go.Layout(plot_bgcolor = black,
                   hovermode = 'x unified',
                   uirevision = 'value')

figure = go.Figure(data = data, layout = layout)

def update_table_style(selectedData):
    table_style_conditions = [{'if': {'row_index': 'odd'},
                               'backgroundColor': 'rgb(240, 240, 240)'}]

    if selectedData != None:
        points_selected = []
        for point in selectedData['points']:
            points_selected.append(point['pointIndex'])
        selected_styles = [{'if': {'row_index': i},
                            'backgroundColor': 'pink'} for i in points_selected]
        table_style_conditions.extend(selected_styles)

    table_style_conditions.extend([{'if': {'row_index': i, 'column_id': 'COLOR'},
                                    'background-color': df.iloc[i]['COLOR'],
                                    'color': df.iloc[i]['COLOR']} for i in range(df.shape[0])])

    return table_style_conditions


# DASHBOARD LAYOUT
app = dash.Dash(external_stylesheets = [dbc.themes.BOOTSTRAP])

app.layout = html.Div(id = 'general_div',
                      children = [html.Div(id = 'first_row',
                                           children = [dcc.Graph(id = 'main_graph',
                                                                 figure = figure,
                                                                 style = {'height': 800,
                                                                          'width': 1400})],

                                           className = 'row'),

                                  html.Div(id = 'second_row',
                                           children = [dash_table.DataTable(id = 'main_table',
                                                                            columns = headers,
                                                                            data = table,
                                                                            # style_data_conditional = table_colors,
                                                                            style_table = {'margin-left': '3vw',
                                                                                           'margin-top': '3vw'},
                                                                            style_cell = {'font-family': fontfamily,
                                                                                          'fontSize': fontsize},
                                                                            style_header = {'backgroundColor': 'rgb(230, 230, 230)',
                                                                                            'fontWeight': 'bold'})],

                                           className = 'row')])


# CALLBACK DEFINITION
@app.callback(Output('main_table', 'style_data_conditional'),
              [Input('main_graph', 'selectedData')])
def display_selected_data(selectedData):
    table_style_conditions = update_table_style(selectedData)
    return table_style_conditions


if __name__ == "__main__":
    app.run_server()

The coloring部分是这样的:

table_style_conditions = [{'if': {'row_index': 'odd'},
                           'backgroundColor': 'rgb(240, 240, 240)'}]

if selectedData != None:
    points_selected = []
    for point in selectedData['points']:
        points_selected.append(point['pointIndex'])
    selected_styles = [{'if': {'row_index': i},
                        'backgroundColor': 'pink'} for i in points_selected]
    table_style_conditions.extend(selected_styles)

table_style_conditions.extend([{'if': {'row_index': i, 'column_id': 'COLOR'},
                                'background-color': df.iloc[i]['COLOR'],
                                'color': df.iloc[i]['COLOR']} for i in range(df.shape[0])])

这是我得到的结果:

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

通过选择散点图上的点来更新虚线表 的相关文章

  • Python speedtest.net,或等效的[关闭]

    Closed 这个问题是无关 help closed questions 目前不接受答案 是否有一个 Python 库可以实现 SpeedTest net 测试或等效的互联网连接速度测试 GitHub上有一个项目叫速度检查 https gi
  • 使用 scikit 时 scipy.sparse 矩阵的缩放问题

    在使用 scikit learn 解决机器学习问题时 我需要在使用 SVM 进行训练之前对 scipy sparse 矩阵进行缩放 但在文档 http scikit learn org stable modules preprocessin
  • 获取 Keras model.summary() 作为表

    我在 Keras 中创建了相当大的模型 我正在用 LaTeX 写一篇关于它的文章 为了很好地描述 LaTeX 中的 keras 模型 我想用它创建一个 LaTeX 表 我可以手动实现它 但我想知道是否有任何 更好 的方法来实现这一点 我四处
  • 如何知道python运行脚本的路径?

    sys arg 0 给我 python 脚本 例如 python hello py 返回 sys arg 0 的 hello py 但我需要知道 hello py 位于完整路径中的位置 我怎样才能用Python做到这一点 os path a
  • multiprocessing.Queue 中的 ctx 参数

    我正在尝试使用 multiprocessing Queue 模块中的队列 实施 https docs python org 3 4 library multiprocessing html exchang objects Between p
  • 单击输入字段会触发窗口调整大小

    我有一个带有徽标 菜单和搜索的标题 当我在桌面上时 我会按该顺序显示所有元素 但如果我的窗口宽度小于 980 像素 菜单会隐藏 有一个切换按钮 并且徽标会与nav并附在徽标之后 如果宽度更大 则徽标将再次分离并附加到 DOM 中的旧位置 w
  • 使组合高度等于浏览器窗口的高度

    http featuredfotografer com http featuredfotografer com Codemirror div 与 header div 结合占用的高度超过了浏览器的高度 我怎样才能使它们的总高度达到浏览器窗口
  • Eclipse/PyDev 中未使用导入警告,尽管已使用

    我正在我的文件中导入一个绘图包 如下所示 import matplotlib pyplot as plt 稍后我会在我的代码中成功使用此导入 fig plt figure figsize 16 10 然而 Eclipse 告诉我 未使用的导
  • Python:导入模块一次然后与多个文件共享

    我有如下文件 file1 py file2 py file3 py 假设这三个都使用 lib7 py lib8 py lib9 py 目前 这三个文件中的每一个都有以下行 import lib7 import lib8 import lib
  • 如何通过selenium中弹出的身份验证?

    我正在尝试使用带有 Selenium 的 Python 脚本加载需要身份验证的网页 options webdriver ChromeOptions prefs download default directory r download de
  • 从网站存储数据的最简单方法(在服务器端)

    我有一个非常简单的网站 实际上是单页 有一个输入字段和一个按钮 我需要将用户提交的数据存储在服务器端的某个位置 完美的方法可能是简单的文本文件 并在每次单击按钮后附加新行 日志文件也可以 据我了解 JavaScript 本身是不可能的 我在
  • 更改时触发跨度文本/html

    jQuery 或 JavaScript 中是否有任何事件在以下情况下触发span标签 text html 已更改 Code span class user location span user location change functio
  • 在 HTML5 中将两个图像合并到一个画布上

    我正在使用 HTML5 canvas 元素 假设我有 2 个 ImageData 对象 我想将它们组合起来放在一张画布上 假设我不关心这些图像如何组合 两个 ImageData 对象具有完全相同的像素数和形状 组合两个图像的最佳方式是什么
  • 如何创建增量加载网页

    我正在编写一个处理大量数据的页面 它会永远持续到我的结果页面加载 几乎无限 因为返回的数据太大了 因此 我需要实现一个增量加载页面 例如 url 中的页面 http docs python org http docs python org
  • 将 Django 中的所有视图限制为经过身份验证的用户

    我是 Django 新手 我正在开发一个项目 该项目有一个登录页面作为其索引和一个注册页面 其余页面都必须仅限于登录用户 如果未经身份验证的用户尝试访问这些页面 则必须将他 她重定向到登录页面 我看到 login required装饰器会将
  • 类返回语句不打印任何输出

    我正在学习课程 但遇到了问题return语句 它是语句吗 我希望如此 程序什么也没有打印出来 它只是结束而不做任何事情 class className def createName self name self name name def
  • iOS Safari Mobile 禁用上一个和下一个选择输入

    上周五我发现了关于此问题的类似问题 但似乎无法再次找到它 如果有人能指出我正确的方向 那就太好了 本质上我在一个页面上有多个选择菜单 第一个在加载时填充 第二个在第一个选择时填充 够简单的 但是 在 iOS 设备中 当您点击选择元素时 它会
  • PyQt5按钮lambda变量变成布尔值[重复]

    这个问题在这里已经有答案了 当我运行下面的代码时 它显示如下 为什么 x 不是 x 而是变成布尔值 这种情况仅发生在传递到用 lambda 调用的函数中的第一个参数上 错误的 y home me model some file from P
  • 检查 IP 地址是否在给定范围内

    我想检查一下是否有IP180 179 77 11位于特定范围之间 例如180 179 0 0 180 179 255 255 我编写了一个函数 它将每个 IP 八位字节与其他八位字节进行比较 def match mask IP min ip
  • 从 Django 运行 shell 命令

    我正在 Django 中开发一个网页 使用 apache 服务器 需要调用 shell 命令来启用 禁用一些守护进程 我尝试这样做 os system service httpd restart 1 gt HOME out 2 gt HOM

随机推荐

  • 属性值是否可以跨越多行?

    e g div class big left important some content div 有谁知道这是否会破坏事情 是否有良好的浏览器支持 考虑回车 制表符等空白 http www sul stanford edu tools t
  • 通过来自同一对象实例(或基础)的反射调用私有/受保护的方法

    是否可以通过反射调用受保护的方法 我正在使用这个 Me GetType InvokeMember Stages CurrentStage Reflection BindingFlags InvokeMethod Nothing Me Not
  • 以编程方式获取 Swift 中当前播放曲目的名称和艺术家

    我已经尝试过以下方法 let nowPlaying MPNowPlayingInfoCenter defaultCenter nowPlayingInfo 然而我回来了nil每次我运行它时都会播放一首歌曲 我希望能够获取曲目标题和艺术家并将
  • 在 Web 开发过程中,我将花费多少时间用于用户输入验证?

    我是网络开发新手 到目前为止 我花了很多时间 50 左右 来尝试阻止坏人将 sql 注入之类的东西放入我的输入表单中并在服务器端验证它 这是正常的吗 Jeremy 一些 PHP 细节 当涉及数据库查询时 请始终尝试使用准备好的参数化查询 这
  • 如何进入 CoreDNS pod kubernetes?

    我有一个正在运行的 k8s 集群 其中包含两个 CoreDNS 副本 但是当我尝试输入 POD 的 bash 提示符时 它向我抛出以下错误 kubectl exec it coredns 5644d7b6d9 285bj n kube sy
  • joomla(2.5)系统插件安装时加载语言文件

    在安装系统插件 在 Joomla 2 5 中 期间 我很难显示本地化字符串 xml 文件中本地化字符串的 正常 方式似乎不起作用 请参阅另一个问题 基于语言的安装描述 https stackoverflow com questions 11
  • 如何跨应用程序限制内容提供商数据

    我们如何确保某些应用程序无法访问存储在内容提供商中的我的数据 而某些其他应用程序可以访问该数据 基本上 我需要允许我感兴趣的某些应用程序访问存储在内容提供程序中的数据 但我不希望所有应用程序都能够访问该数据 我怎样才能实现这个目标 Than
  • 获取代码点的所有 Unicode 别名

    The charnames https metacpan org pod charnames杂注提供charnames viacode返回给定代码点的 最佳 名称 例如 perl Mcharnames full E say charname
  • 使用插件系统的 Netbeans 平台应用程序

    我正在编写一个 Netbeans 平台应用程序 我想在该应用程序处于开发状态时将其提供给客户 并且每当特定模块有更新时 我想以客户可以使用 netbeans 插件更新程序来更新模块的方式处理它 因此 我将获得一台服务器来托管不同的模块 签署
  • (iphone)将子视图的框架设置在超级视图的边界之外?

    我注意到我可以将子视图放置在超级视图的边界之外 部分或全部 我想知道这是否可以接受 因为这在通常的 iPhone 视图编程中似乎是不正常的 谢谢 这是可以接受的 有时甚至是常见的做法 例如 滚动视图或其他 复合 视图的自定义实现通常会将对象
  • 在Python中对多维数组进行排序的适当数据结构?

    我有各种字符串 单词 的三个数值 权重 计数 贡献 我想将它们组织成一个多维数组 然后进行排序 为此 我在字典中创建了列表 其中数值位于列表中 字符串是键 print dictionary word weight count contrib
  • 编写自己的异步方法

    我想知道如何以 正确 的方式编写自己的异步方法 我看过很多解释异步 等待模式的帖子 如下所示 http msdn microsoft com en us library hh191443 aspx http msdn microsoft c
  • 什么是域错误

    在 C 中 有一个 域错误 的基类 std domain error 我不明白在什么情况下我应该在代码中抛出域错误 所有其他异常基类都非常不言自明 我很确定 std domain error 本身与互联网域名无关 因此请解释域错误是什么类别
  • 如何用intellij中的空格序列替换文件中的所有制表符?

    给定项目中的一个文件 我希望能够用空格替换文件中的所有制表符 intellij 有什么办法可以做到这一点吗 转到编辑 转换缩进 然后分别选择 到空格 或 到制表符 它在文档中 改变缩进 http www jetbrains com idea
  • Python 是否内置了针对特殊字符和/或标点符号的字符串验证?

    Python 有str isalnum str isdigit str isupper str islower str isalpha 但是它是否有任何内置的字符串验证检查特殊字符或标点符号 即 等 标准string模块提供string p
  • 如何以编程方式获取Linux进程的堆栈起始地址和结束地址?

    对于单线程程序 我想检查给定的虚拟地址是否在进程的堆栈中 我想在用 C 编写的进程中执行此操作 我正在考虑读书 proc self maps找到标记为 stack 的行 以获取进程堆栈的开始和结束地址 思考这个解决方案让我产生了以下问题 p
  • java系统范围的键盘和鼠标状态

    有没有办法在系统范围内侦听鼠标和键盘事件 而不将它们从系统队列中取出 例如 有没有办法设置一个恶魔 比如说 它会监听并报告每个键盘和鼠标事件 使用纯Java 是不可能的 但是您可以使用 JNI Java 本机接口 它适用于用 C 编写并本机
  • UPDATE 语句包含在 IF EXISTS 块中

    我正在尝试编写一个更新列的 DML 脚本 但我想确保该列首先存在 因此我将其包装在 IF EXISTS 块中 IF EXISTS SELECT FROM INFORMATION SCHEMA COLUMNS WHERE TABLE NAME
  • 如果消息被编辑,防咒骂系统将不起作用

    基本上 如果您说了一些不是脏话的内容 但随后将消息编辑为脏话 机器人将不会检测到它 我该如何解决 这是我的代码 client event async def on message message if message author bot
  • 通过选择散点图上的点来更新虚线表

    我正在制作仪表板 这是我的代码 IMPORT SECTION import dash import dash table import dash core components as dcc import dash html compone