【发布时间】:2019-11-22 20:23:21
【问题描述】:
我是 dash 的新手,我正在尝试制作一个基本表格以显示在 IP 上供所有人查看。这可以防止需要电子邮件或将数据放置在任何特定位置。我使用以下代码创建了一个从文档中提取的非常简单的仪表板,但我想定期更新仪表板。为此,我使用任务调度程序每 30 分钟运行一次代码,杀死旧实例。这样,当“data.csv”更新时,表格中将显示一个新的数据框。
import dash
import dash_core_components as dcc
import dash_html_components as html
import pandas as pd
df = pd.read_csv('data.csv')
def generate_table(dataframe, max_rows=30):
return html.Table(
# Header
[html.Tr([html.Th(col) for col in dataframe.columns])] +
# Body
[html.Tr([
html.Td(dataframe.iloc[i][col]) for col in dataframe.columns
]) for i in range(min(len(dataframe), max_rows))]
)
external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
app = dash.Dash(__name__, external_stylesheets=external_stylesheets)
app.layout = html.Div(children=[
html.H4(children='Title'),
generate_table(df, max_rows=len(df))
])
if __name__ == '__main__':
ADDRESS='100.100.100.100' #ipv4 address for computer code is run on
PORT=int(1000)
app.run_server(debug=True, host=ADDRESS, port=PORT)
我的问题是,尽管重新启动实例并更改了 csv,但只会显示原始 csv 数据。我只能通过更改端口并启动一个新应用程序来修复它,这不是我想要的选项。如何使用新的 csv 信息更新相同的应用程序?
【问题讨论】:
标签: python plotly-dash