Диаграмма Dash / Plotly не отображается при запуске из Raspberry PI - PullRequest
0 голосов
/ 09 октября 2019

Я пытаюсь отобразить данные в реальном времени с Raspberry Pi на веб-сервере. В этом случае для этого я использую dash (https://dash.plot.ly/live-updates)). В настоящее время я тестирую свой веб-браузер dash на статических данных на моем Mac, и пока он работает просто отлично. Помимо сообщения об устаревшем графике, иa Не удалось найти обработчики для регистратора "werkzeug", он работает совершенно нормально. НО, когда я пытаюсь запустить точно такой же скрипт на моем Raspberry Pi, возникают проблемы.

На моем Raspberry Pi, веб-серверезапускается, я могу открыть его на локальном хосте, но диаграммы пусты !!! У меня нет сообщений об ошибках или причин, почему это происходит!

What pops up on the Pi

What pops up on my Mac

РЕДАКТИРОВАТЬ: Сценарий добавлен

import os, sys
from pathlib import Path
currDir = Path(os.path.abspath(__file__))
_rootDir = currDir.parent.parent
# _dataDir = str(_rootDir / 'GridBallast-RaspberryPI' / 'data')
_dataDir = str(_rootDir / 'data')


import ETL
import datetime
import dash
import dash_core_components as dcc
import dash_html_components as html
import plotly
from dash.dependencies import Input, Output

external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']

app = dash.Dash(__name__, external_stylesheets=external_stylesheets)
app.layout = html.Div(
    html.Div([
        html.H4('RaspberryPI Sensor Charts'),
        html.Div(id='live-update-text'),
        dcc.Graph(id='live-update-graph'),
        dcc.Interval(
            id='interval-component',
            interval=1*1000, # in milliseconds
            n_intervals=0
        )
    ])
)


@app.callback(Output('live-update-text', 'children'),
              [Input('interval-component', 'n_intervals')])
def update_metrics(n):
    Temperature, Time = ETL.extractLastTemp(os.path.join(_dataDir, 'tempData.csv'))
    style = {'padding': '2px', 'fontSize': '16px'}
    return [
        html.Span('Temperature: {}'.format(Temperature), style=style),
        html.Span('Time: {}'.format(Time), style=style)
    ]


@app.callback(Output('live-update-graph', 'figure'),
              [Input('interval-component', 'n_intervals')])

def update_graph_live(n):

    #Load Temp Data 
    tempDict = ETL.etlTransform(os.path.join(_dataDir, 'tempData.csv'))
    lightDict = ETL.etlTransform(os.path.join(_dataDir, 'lightData.csv'))
    currentDict = ETL.etlTransform(os.path.join(_dataDir, 'currentData.csv'))
    # Create the graph with subplots
    fig = plotly.tools.make_subplots(rows=3, cols=1, vertical_spacing=0.2, subplot_titles=("Temperature", "Light", "Current"))
    fig['layout']['margin'] = {
        'l': 30, 'r': 10, 'b': 30, 't': 25
    }
    fig['layout']['legend'] = {'x': 0, 'y': 1, 'xanchor': 'left'}
    fig['layout']['height'] = 900

    fig.append_trace({
        'x': tempDict.keys(),
        'y': tempDict.values(),
        'name': 'Temp vs. Time',
        'mode': 'lines+markers',
        'type': 'scatter'
    }, 1, 1)
    fig.append_trace({
        'x': lightDict.keys(),
        'y': lightDict.values(),
        # 'text': data['time'],
        'name': 'Light vs. Time',
        'mode': 'markers',
        'type': 'scatter'
    }, 2, 1)
    fig.append_trace({
        'x': currentDict.keys(),
        'y': currentDict.values(),
        # 'text': data['time'],
        'name': 'Current vs. Time',
        'mode': 'markers',
        'type': 'scatter'
    }, 3, 1)

    return fig


def main():
    app.run_server(debug = True)

if __name__ == '__main__':
    print(_dataDir)
    print(os.listdir(_dataDir))
    main()
    # app.run_server(debug=True)

1 Ответ

0 голосов
/ 09 октября 2019

, поэтому я смог решить проблему, увеличив интервал обновления. Я думаю, на Raspberry Pi интервал должен быть больше, чтобы график корректно обновлялся. Странно, но это работает.

...