Passing Django Database Queryset to Highcharts via JSON

后端 未结 1 1129
刺人心
刺人心 2020-12-01 08:48

First time poster, long time reader. I\'ve spend quite awhile looking for an answer to this, which makes me think its something fundamental I\'m missing.

I\'m tryin

1条回答
  •  执笔经年
    2020-12-01 09:32

    I finally got my plotting working. I found this approach here. Thanks to Harrison for posting his method!

    My new views.py based on the above approach:

    def plot(request, chartID = 'chart_ID', chart_type = 'line', chart_height = 500):
        data = ChartData.check_valve_data()
    
        chart = {"renderTo": chartID, "type": chart_type, "height": chart_height,}  
        title = {"text": 'Check Valve Data'}
        xAxis = {"title": {"text": 'Serial Number'}, "categories": data['serial numbers']}
        yAxis = {"title": {"text": 'Data'}}
        series = [
            {"name": 'Mass (kg)', "data": data['mass']}, 
            {"name": 'Pressure Drop (psid)', "data": data['pressure drop']},
            {"name": 'Cracking Pressure (psid)', "data": data['cracking pressure']}
            ]
    
        return render(request, 'unit/data_plot.html', {'chartID': chartID, 'chart': chart,
                                                        'series': series, 'title': title, 
                                                        'xAxis': xAxis, 'yAxis': yAxis})
    

    Quick function for pulling database objects and passing the data:

    class ChartData(object):    
        def check_valve_data():
            data = {'serial numbers': [], 'mass': [],
                     'pressure drop': [], 'cracking pressure': [], 'reseat pressure': []}
    
            valves = CheckValve.objects.all()
    
            for unit in valves:
                data['serial numbers'].append(unit.serial_number)
                data['mass'].append(unit.mass)
                data['cracking pressure'].append(unit.cracking_pressure)
                data['pressure drop'].append(unit.pressure_drop)
                data['reseat pressure'].append(unit.reseat_pressure)
    
            return data   
    

    The key to Harrison's method is a mapping script to translate the Highcharts js to Python template variables:

    {% extends "base.html" %}
    
    {% block extrahead %}
        
        
        
    {% endblock %}
    
    {% block heading %}
        

    Analysis

    {% endblock %} {% block content %}
    {% endblock %} {% block overwrite %} {% endblock %} {% block extrajs %} {% endblock %}

    Everything works and displays correctly now!

    0 讨论(0)
提交回复
热议问题